生成带重复的笛卡尔乘积过程 Cartesian Product with Repetition
What is Cartesian Product with Repetition
比如说有两个集合:
\(\{1, 2, 3\}\)
\(\{A, B, C\}\)
想把他们组合成所有可能组合,比如,
1AAA
1AAB
1AAC
...
这种组合可以称为"有重复的笛卡尔积"或"带重复的笛卡尔乘积"(Cartesian Product with Repetition)。
带重复的笛卡尔乘积(Cartesian Product with Repetition)具有以下特征:
涉及两个或多个集合:它是针对两个或更多个集合进行操作。在您的示例中,涉及两个集合{1, 2, 3}和{A, B, C}。
元素可以重复出现:与传统的笛卡尔积不同,在带重复的笛卡尔乘积中,同一个集合中的元素可以在生成的组合中多次出现。在您的示例中,第二个集合{A, B, C}中的元素可以在组合中重复出现,比如AAA、ABB等。
生成的组合长度固定:生成的组合的长度是事先确定的,等于参与集合的数量。在您的示例中,生成的组合长度为2,因为涉及两个集合。
组合的排列顺序不同视为不同组合:生成的组合中,元素的排列顺序不同就被视为不同的组合。例如,AB和BA是两个不同的组合。
组合数量呈指数级增长:随着参与集合的元素数量增加,生成的组合数量会呈指数级增长。如果有n个集合,每个集合有m个元素,那么生成的组合数量将是m^n。
总的来说,带重复的笛卡尔乘积是一种特殊的组合形式,它允许元素重复出现。
Code Demo
import java.util.ArrayList;
import java.util.List;
public class Combination {
public static void main(String[] args) {
List<String> list1 = new ArrayList<>();
list1.add("1");
list1.add("2");
list1.add("3");
List<String> list2 = new ArrayList<>();
list2.add("A");
list2.add("B");
list2.add("C");
// 用于存储所有可能的组合
List<String> combinations = new ArrayList<>();
// 遍历第一个列表中的每个元素
// 遍历list1中的每个元素,对于每个元素:
// 调用generateCombinations方法,将list2和list2的长度作为参数传递进去,并将生成的组合添加到combinations列表中。
for (String item1 : list1) {
// 对于每个元素,生成第二个列表中元素的所有可能组合,并添加到 combinations 列表中
combinations.addAll(generateCombinations(list2, list2.size(), item1));
}
// 打印所有可能的组合
System.out.println("所有可能的组合:");
for (String combination : combinations) {
System.out.println(combination);
}
}
/**
* 生成第二个列表中元素的所有可能组合
*
* @param list 第二个列表
* @param length 要生成的组合长度
* @param prefix 已经选择的元素前缀
* @return 所有可能的组合
*/
private static List<String> generateCombinations(List<String> list, int length, String prefix) {
// 所有可能的组合 存储
List<String> combinations = new ArrayList<>();
// 如果要生成的组合长度为 0,说明已经生成了所有元素的组合
if (length == 0) {
// 将前缀添加到结果列表中并返回
combinations.add(prefix);
return combinations;
}
// 遍历第二个列表中的每个元素
for (int i = 0; i < list.size(); i++) {
// 将当前元素追加到前缀中
String newPrefix = prefix + list.get(i);
// 递归调用 generateCombinations 方法,将 length 减 1,并将新的前缀作为参数传递进去
combinations.addAll(generateCombinations(list, length - 1, newPrefix));
}
return combinations;
}
}
out:
所有可能的组合:
1AAA
1AAB
1AAC
1ABA
1ABB
1ABC
1ACA
1ACB
1ACC
1BAA
1BAB
1BAC
1BBA
1BBB
1BBC
1BCA
1BCB
1BCC
1CAA
1CAB
1CAC
1CBA
1CBB
1CBC
1CCA
1CCB
1CCC
2AAA
2AAB
2AAC
2ABA
2ABB
2ABC
2ACA
2ACB
2ACC
2BAA
2BAB
2BAC
2BBA
2BBB
2BBC
2BCA
2BCB
2BCC
2CAA
2CAB
2CAC
2CBA
2CBB
2CBC
2CCA
2CCB
2CCC
3AAA
3AAB
3AAC
3ABA
3ABB
3ABC
3ACA
3ACB
3ACC
3BAA
3BAB
3BAC
3BBA
3BBB
3BBC
3BCA
3BCB
3BCC
3CAA
3CAB
3CAC
3CBA
3CBB
3CBC
3CCA
3CCB
3CCC
生成带重复的笛卡尔乘积过程 Cartesian Product with Repetition的更多相关文章
- [转]sql语句中出现笛卡尔乘积 SQL查询入门篇
本篇文章中,主要说明SQL中的各种连接以及使用范围,以及更进一步的解释关系代数法和关系演算法对在同一条查询的不同思路. 多表连接简介 在关系数据库中,一个查询往往会涉及多个表,因为很少有数据库只有一个 ...
- ASP.NET MVC中实现属性和属性值的组合,即笛卡尔乘积02, 在界面实现
在"ASP.NET MVC中实现属性和属性值的组合,即笛卡尔乘积01, 在控制台实现"中,在控制台应用程序中实现了属性值的笛卡尔乘积.本篇在界面中实现.需要实现的大致如下: 在界面 ...
- sql语句中出现笛卡尔乘积 SQL查询入门篇
2014-12-29 凡尘工作室 阅 34985 转 95 本篇文章中,主要说明SQL中的各种连接以及使用范围,以及更进一步的解释关系代数法和关系演算法对在同一条查询的不同思路. 多表连接简介 ...
- ASP.NET MVC中实现属性和属性值的组合,即笛卡尔乘积01, 在控制台实现
在电商产品模块中必经的一个环节是:当选择某一个产品类别,动态生成该类别下的所有属性和属性项,这些属性项有些是以DropDownList的形式存在,有些是以CheckBoxList的形式存在.接着,把C ...
- sql语句中出现笛卡尔乘积
没有join条件导致笛卡尔乘积 学过线性代数的人都知道,笛卡尔乘积通俗的说,就是两个集合中的每一个成员,都与对方集合中的任意一个成员有关联.可以想象,在SQL查询中,如果对两张表join查询而没有jo ...
- Mysql训练:两个表中使用 Select 语句会导致产生 笛卡尔乘积 ,两个表的前后顺序决定查询之后的表顺序
力扣:超过经理收入的员工 Employee 表包含所有员工,他们的经理也属于员工.每个员工都有一个 Id,此外还有一列对应员工的经理的 Id. +----+-------+--------+----- ...
- 笛卡尔遗传规划Cartesian Genetic Programming (CGP)简单理解(1)
初识遗传算法Genetic Algorithm(GA) 遗传算法是计算数学中用于解决最优化的搜索算法,是进化算法的一种.进化算法借鉴了进化生物学中的一些现象而发展起来的,这些现象包括遗传.突变.自然选 ...
- js实现的笛卡尔乘积-商品发布
//笛卡儿积组合 function descartes(list) { //parent上一级索引;count指针计数 var point = {}; var result = []; var pIn ...
- 笛卡尔乘积 python语法
修改为 bot_name = spider.settings.attributes['BOT_NAME'].value tablenameCommon = 'amazon_hot_new_releas ...
- Js笛卡尔乘积
self.getDescartesSku = function (selSaleProp, i, nowLst, allALst) { if (selSaleProp.length = ...
随机推荐
- kingbaseES sql 优化技巧汇总
1.整体思路 针对业务系统的出现的慢sql 我们的优化步骤大概分为以下几步 1.识别高负载语句 2.收集性能相关的数据 3.确定性能问题产生的原因 4.实施优化手段 下面我们针对这几个步骤展开进行讲解 ...
- 探索Django REST框架构建强大的API
本文分享自华为云社区<探索Django REST框架构建强大的API>,作者:柠檬味拥抱. 在当今的Web开发中,构建强大的API已经成为了不可或缺的一部分.而在Python领域,Djan ...
- #树形dp#C 树上排列
分析 设\(dp[x][i]\)表示以\(x\)为根的子树中\(x\)的排名为\(i\)的方案数, 然后枚举子节点转移即可,Talk is cheap,Show me the code 代码 #inc ...
- #容斥,搜索,线性筛#CF83D Numbers
洛谷 CF83D 分析 题意就是\(\sum_{i=l}^r[k|i]*[mn[\frac{i}{k}]\geq k]\) 首先线性筛每个数的最小质因数,如果\(\frac{r}{k}\)较小直接暴力 ...
- 重新整理 .net core 实践篇———承载[外篇]
前言 简单介绍一下承载. 正文 名称叫做承载,其实就是.net core 定义的一套长期运行的服务的规范. 这个服务可以是web服务,也可以是其他服务,比如tcp,或者一些监控服务. 这里以监控服务为 ...
- Caused by: org.gradle.api.internal.artifacts.ivyservice.DefaultLenientConfiguration$ArtifactResolveException: Could not resolve all files for configuration ':classpath'.
前言 这个错误怎么看呢? 如果你对gradle 不是很了解的话,有一个建议,就是把异常背下来,当然是看这个:ArtifactResolveException哈. 而不是后面的详情. 正文 给我们详情是 ...
- Unity性能优化——托管堆/GC
了解托管堆 许多 Unity 开发者面临的另一个常见问题是托管堆的意外扩展.在 Unity 中,托管堆的扩展比收缩容易得多.此外,Unity 的垃圾收集策略往往会使内存碎片化,因此可能阻止大型堆的收缩 ...
- 图片验证码识别,标签中onehot编码对应多个1怎么做?
一张验证码图片直接做整体识别 也就是图片的最后输出节点有4*26=104个,经过一个softmax,使用交叉熵损失,与真实值4*26=104个标签做计算,然后反向传播 104个onehot编码真实值当 ...
- 使用JSZip实现在浏览器中操作文件与文件夹
1. 引言 浏览器中如何创建文件夹.写入文件呢? 答曰:可以借助JSZip这个库来实现在浏览器内存中创建文件与文件夹,最后只需下载这个.zip文件,就是最终得结果 类似的使用场景如下: 在线下载很多图 ...
- 从 Flink Forward Asia 2021,看Flink未来开启新篇章
简介:本文将对FFA Keynote议题作一些简单的归纳总结,感兴趣的小伙伴们可以在FFA官网[2]找到相关主题视频观看直播回放. 作者 | 梅源(Yuan Mei) 来源 | 阿里技术公众号 ...