`
licweiwei
  • 浏览: 10669 次
  • 性别: Icon_minigender_1
  • 来自: SuZhou
社区版块
存档分类
最新评论

ECC Concept Rule Generation

 
阅读更多

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;


public class Zuhe  {

    public static void main(String[] args) throws Exception {
        Zuhe zhuhe = new Zuhe();
        zhuhe.printAll("1,2/9,3,4/10,5/6/7/8");
    }

    /**
     *
     */
    public void printAll(String input) throws Exception {
        String[] elementArray = input.split(",");
        Map<String, String[]> elementAlias = new HashMap<String, String[]>();
        int length = elementArray.length;
        for (int i = 0; i < length; i++) {
            if (elementArray[i].indexOf("/") > 0) {
                String[] alias = elementArray[i].split("/");
                elementArray[i] = alias[0];
                String[] aliasArray = new String[alias.length - 1];
                System.arraycopy(alias, 1, aliasArray, 0, alias.length - 1);
                elementAlias.put(alias[0], aliasArray);
            }
        }
        List<String[]> result = new ArrayList<String[]>();
        for (int i = 2; i <= length; i++) {
            result.addAll(combine(elementArray, i));
        }
        result = processAlias(result,elementAlias);
        print(result);
    }

    public List<String[]> combine(String[] elements, int m) throws Exception {
        int n = elements.length;
        if (m > n) {
            throw new Exception("m>n");
        }

        List<String[]> result = new ArrayList<String[]>();


        int[] bs = new int[n];
        for (int i = 0; i < n; i++) {
            bs[i] = 0;
        }
        //初始化
        for (int i = 0; i < m; i++) {
            bs[i] = 1;
        }
        if (m == n) {
            result.add(print(bs, elements, m));
            return result;
        }
        boolean flag;
        boolean tempFlag;
        int pos;
        int sum;
        //首先找到第一个10组合,然后变成01,同时将左边所有的1移动到数组的最左边
        do {
            sum = 0;
            pos = 0;
            tempFlag = true;
            result.add(print(bs, elements, m));

            for (int i = 0; i < n - 1; i++) {
                if (bs[i] == 1 && bs[i + 1] == 0) {
                    bs[i] = 0;
                    bs[i + 1] = 1;
                    pos = i;
                    break;
                }
            }
            //将左边的1全部移动到数组的最左边

            for (int i = 0; i < pos; i++) {
                if (bs[i] == 1) {
                    sum++;
                }
            }
            for (int i = 0; i < pos; i++) {
                if (i < sum) {
                    bs[i] = 1;
                } else {
                    bs[i] = 0;
                }
            }

            //检查是否所有的1都移动到了最右边
            for (int i = n - m; i < n; i++) {
                if (bs[i] == 0) {
                    tempFlag = false;
                    break;
                }
            }
            flag = !tempFlag;

        } while (flag);
        result.add(print(bs, elements, m));

        return result;
    }

    private String[] print(int[] bs, String[] a, int m) {
        String[] result = new String[m];
        int pos = 0;
        for (int i = 0; i < bs.length; i++) {
            if (bs[i] == 1) {
                result[pos] = a[i];
                pos++;
            }
        }
        return result;
    }

    private void print(List<String[]> l) {
        for (String[] a : l) {
            for (String anA : a) {
                System.out.print(anA + " ");
            }
            System.out.println();
        }
    }

    private List<String[]> processAlias(List<String[]> l, Map<String, String[]> alias) {
        List<String[]> result = new ArrayList<String[]>();
        result.addAll(l);
        for (String[] a : l) {
            for (int i = 0; i < a.length; i++) {
                if (alias.containsKey(a[i])) {
                    String[] aliasArray = alias.get(a[i]);
                    for (String aliasElement : aliasArray) {
                        String[] b = new String[a.length];
                        System.arraycopy(a, 0, b, 0, a.length);
                        b[i] = aliasElement;
                        result.add(b);
                    }
                }
            }
        }
        return result;
    }
}
分享到:
评论

相关推荐

    gensim-4.1.0-cp37-cp37m-manylinux_2_12_x86_64.manylinux2010_x86_64.whl.zip

    gensim-4.1.0-cp37-cp37m-manylinux_2_12_x86_64.manylinux2010_x86_64.whl.zip

    IMG_6610.jpg

    IMG_6610.jpg

    原理图与PCB设计.iso,值得一看

    原理图与PCB设计.iso,值得一看

    基于SpringBoot的同城上门喂遛宠物系统(源码+数据库+万字文档)357

    同城上门喂遛宠物系统,系统包含两种角色:管理员、用户,系统分为前台和后台两大模块,主要功能如下。 前台: - 首页:展示系统的概览信息。 - 爱宠天地:提供爱宠人士交流、学习讨论的平台。 - 宠物:展示宠物相关的信息。 - 宠物资讯:提供宠物行业相关的新闻、资讯、科普文章等。 - 个人中心:用户可以登录后进入个人中心,管理个人信息,查看宠物预约记录、服务订单、评价等。 后台: 管理员角色: - 个人中心:管理员可以管理个人信息,修改密码等。 - 管理员管理:管理员可以对其他管理员的信息进行增删改查等操作。 - 用户管理:管理员可以对用户的信息进行增删改查等操作。 - 爱宠天地管理:管理员可以管理交流论坛的帖子、评论,审核内容等。 - 宠物管理:管理员可以管理宠物的基本信息,包括宠物种类、照片、描述等。 - 宠物预约管理:管理员可以处理用户的宠物预约请求,安排服务人员等。 - 宠物资讯管理:管理员可以管理宠物行业相关的新闻、资讯、科普文章等。 - 基础数据管理:管理员可以管理基础数据,包括宠物种类、服务类型、服务时长、价格等。 - 轮播图信息:管理员可以管理轮播图信息,包括添加、修改

    静态综合实验报告模板.docx

    静态综合实验报告模板.docx

    USB_UVC_Timing.v

    USB_UVC_Timing.v

    【最新版】 ISO 21207-2015.rar

    【最新版】 ISO 21207-2015.rar

    英语培训课程-词汇语法基础

    英语培训课程-词汇语法基础

    ai产品经理面试高频100题

    ai产品经理面试高频100题

    PW1X-PHP+XLS_1个通用条件工资成绩等通用查询系统电脑网页版版(Gb2312)_2024最终版.zip

    PW1X-PHP+XLS_1个通用条件工资成绩等通用查询系统电脑网页版版(Gb2312)_2024最终版

    基于SpringBoot的精品水果线上销售网站(源码+数据库+万字文档)337

    精品水果线上销售网站,系统包含三种角色:管理员、商家、用户,系统分为前台和后台两大模块,主要功能如下。 前台功能: 1. 首页:展示水果的推荐信息和促销活动。 2. 公告:展示网站的公告信息。 3. 招商加盟:介绍招商加盟的政策和流程。 4. 联系我们:提供联系方式和在线留言功能。 5. 网站介绍:详细介绍网站的特色和服务内容。 6. 商家:用户可以查看商家的信息和合作方式。 7. 水果:用户可以浏览水果的详细信息。 8. 个人中心:用户可以管理个人信息、订单记录、收货地址等。 9. 购物车:用户可以将感兴趣的水果添加到购物车。 后台功能: 用户: 1. 个人中心:管理个人信息。 2. 公告管理:管理公告信息,包括添加、编辑、删除公告等操作。 3. 水果管理:管理水果信息,包括添加、编辑、删除水果等操作。 管理员: 1. 个人中心:管理个人信息。 2. 基础数据管理:管理基础数据,包括水果分类、产地信息等。 3. 公告管理:管理公告信息,包括添加、编辑、删除公告等操作。 4. 水果管理:管理水果信息,包括添加、编辑、删除水果等操作。 5. 单页数据管理:管理网站单页信息,

    奔图P3305固件P3305DN固件

    解决间歇性不上纸

    google play store 安卓apk安装包

    google play store 安卓apk安装包,内置google服务 在网络情况允许的情况下,就可以直接使用 Google Play 是一个在线商店,用户可以在其中找到喜爱的应用、游戏、电影、电视节目和图书等。 它向全球数十亿用户提供 200 万款应用和游戏, 迄今为止为开发者带来了超过 1200 亿美元的收入。 我们在开发者与全球数十亿用户之间建立纽带,同时投资于平台、工具、服务和营销机会,为在全球范围内推广应用和游戏提供支持。

    云原生训练营开播:从理论到实践,涵盖容器化、服务网格与CI/CD

    内容概要:本文详尽介绍了云原生技术,不仅涵盖了基本概念和技术架构的介绍,还深入讲解了云原生的核心元素,例如容器化、服务网格、不可变基础设施与声明式API的应用。文章指出云原生是一种结合了特定技术和理念的方法论,旨在提高系统适应性、可管理性和可观测性,并加快想法到市场的进程(I2M)。同时,文中探讨了云原生的实际实施路径,强调自动化的价值,以及在现代云计算环境下持续交付的价值链。另外,文章也提到了学员在参加云原生训练营时可能面临的挑战,鼓励他们通过不断的探索与实践来深化对于这一领域的理解。除此之外,它提供了关于kube-proxy的工作机制解释,指出了最佳的学习方式即先阅读官方文档建立基础知识,再深入探究社区分享的经验,最后达到对技术的全面掌控。 适合人群:本文主要面向希望通过学习云原生及其相关技术实现自我技能提升的开发者和工程师群体;尤其是那些希望了解如何利用云平台特性来优化自身产品和服务的个人。 使用场景及目标:对于正在寻找构建、迁移至云端解决方案的人来说,本篇文章有助于他们理解如何设计云优先的软件架构;同时也能帮助企业更好地评估自身IT战略是否符合未来发展方向的要求。其终极目的是为

    最新更新!中国各省市气候风险指数(1993-2023)31个省份,共962个省级样本;227个地级市,共6950个地级市样本

    ## 介绍 气候风险指数是基于历史气候资料和未来气候预测结果,通过判断极端天气气候事件致灾阈值、结合社会经济数据及实际灾害损失分析,采用科学的方法对单一或综合气候灾害风险进行的定量化评价。 ## 一、中国各省市气候风险数据的介绍 中国各省市气候风险数据主要包括极端低温、极端高温、极端降雨及极端干旱日数的相关数据,可为研究者进行气候风险评估、应对气候变化策略的制定及区域发展提供数据支持。 数据年份:1993-2023年 数据样本:31个省份,共962个省级样本;227个地级市,共6950个地级市样本 ## 二、数据指标

    MoPaaS.智泊AI首创年薪60W+ AGI大模型进阶技术路线图V5.0.png

    关注有更多资源,私信免费的

    最新更新!上市公司-供应链风险数据测算+dofile(2008-2023年)

    ## 介绍 A股上市公司企业供应链风险是指在企业运营过程中,由于供应链各环节的波动和不稳定,导致企业面临的生产、销售和财务风险。随着市场环境的变化,A股上市公司在全球化竞争中暴露出越来越多的供应链风险问题。 ## 一、A股上市公司企业供应链风险的介绍 A股上市公司企业供应链风险主要源自上下游供需关系的波动。随着市场需求的不确定性增加,企业在生产、库存和销售环节的风险逐步上升。 本分享数据集合2008-2023年5024家A股上市公司数据,共4.3万样本,为各位学者研究A股上市公司在供应链管理方面面临的风险变化提供数据支持。 ## 二、数据指标

    5DMCITY.COM.dll

    5DMCITY.COM

    最新更新!商道融绿ESG评级数据(2015-2024年)

    ## 介绍 商道融绿ESG评级数据为企业提供了全面的环境、社会和治理(ESG)评级信息。这些数据涵盖了不同行业的公司,根据不同企业的表现,评级结果分为十个等级:D、C-、C、C+、B-、B、B+、A-、A、A+。每个等级对应不同的得分,最高为A+,最低为D ## 一、商道融绿ESG评级数据的介绍 商道融绿的ESG评级覆盖全部中国境内上市公司,港股通中的香港上市公司,以及主要的债券发行主体,评级结果和具体ESG数据可广泛应用于投资决策、风险管理、政策制定、可持续金融产品的创新和研发 数据年份:2015-2024年 数据格式:excel ## 二、数据指标 ## 三、测算方式 商道融绿ESG评级总分由两个主要部分组成:ESG主动管理得分和ESG风险暴露得分。通过综合环境、社会和治理三个一级指标的得分来计算总分。具体测算过程如下: - ESG主动管理得分:根据公司在环境、社会责任、治理等方面的具体措施和成效进行打分 - ESG风险暴露得分:根据公司面临的ESG相关风险进行评估和打分 最终的ESG评级总分由这两部分得分相加得出

Global site tag (gtag.js) - Google Analytics