本文实例讲述了Java笛卡尔积算法原理与实现方法。分享给大家供大家参考,具体如下:

笛卡尔积算法的Java实现:

(1)循环内,每次只有一列向下移一个单元格,就是CounterIndex指向的那列。

(2)如果该列到尾部了,则这列index重置为0,而CounterIndex则指向前一列,相当于进位,把前列的index加一。

(3)最后,由生成的行数来控制退出循环。

public class Test {

private static String[] aa = { "aa1", "aa2" };

private static String[] bb = { "bb1", "bb2", "bb3" };

private static String[] cc = { "cc1", "cc2", "cc3", "cc4" };

private static String[][] xyz = { aa, bb, cc };

private static int counterIndex = xyz.length - 1;

private static int[] counter = { 0, 0, 0 };

public static void main(String[] args) throws Exception {

for (int i = 0; i < aa.length * bb.length * cc.length; i++) {

System.out.print(aa[counter[0]]);

System.out.print("\t");

System.out.print(bb[counter[1]]);

System.out.print("\t");

System.out.print(cc[counter[2]]);

System.out.println();

handle();

}

}

public static void handle() {

counter[counterIndex]++;

if (counter[counterIndex] >= xyz[counterIndex].length) {

counter[counterIndex] = 0;

counterIndex--;

if (counterIndex >= 0) {

handle();

}

counterIndex = xyz.length - 1;

}

}

}

输出共2*3*4=24行:

aa1 bb1 cc1

aa1 bb1 cc2

aa1 bb1 cc3

aa1 bb1 cc4

aa1 bb2 cc1

aa1 bb2 cc2

aa1 bb2 cc3

aa1 bb2 cc4

aa1 bb3 cc1

aa1 bb3 cc2

aa1 bb3 cc3

aa1 bb3 cc4

aa2 bb1 cc1

aa2 bb1 cc2

aa2 bb1 cc3

aa2 bb1 cc4

aa2 bb2 cc1

aa2 bb2 cc2

aa2 bb2 cc3

aa2 bb2 cc4

aa2 bb3 cc1

aa2 bb3 cc2

aa2 bb3 cc3

aa2 bb3 cc4

最近碰到了一个笛卡尔积的算法要求,比如传递过来的参数是"1,3,6,7==4,5,8,9==3,4==43,45,8,9==35,4",则返回的是一个list,如[1,4,3,43,35][1,4,3,43,4][1,4,3,45,35]……,该list包含是4*4*2*4*2=256个元素,现在的思路是这样的:

import java.util.ArrayList;

import java.util.Arrays;

import java.util.List;

public class DescartesTest {

/**

* 获取N个集合的笛卡尔积

*

* 说明:假如传入的字符串为:"1,2,3==5,6==7,8"

* 转换成字符串数组为:[[1, 2, 3], [5, 6], [7, 8]]

* a=[1, 2, 3]

* b=[5, 6]

* c=[7, 8]

* 其大小分别为:a_length=3,b_length=2,c_length=2,

* 目标list的总大小为:totalSize=3*2*2 = 12

* 对每个子集a,b,c,进行循环次数=总记录数/(元素个数*后续集合的笛卡尔积个数)

* 对a中的每个元素循环次数=总记录数/(元素个数*后续集合的笛卡尔积个数)=12/(3*4)=1次,每个元素每次循环打印次数:后续集合的笛卡尔积个数=2*2个

* 对b中的每个元素循环次数=总记录数/(元素个数*后续集合的笛卡尔积个数)=12/(2*2)=3次,每个元素每次循环打印次数:后续集合的笛卡尔积个数=2个

* 对c中的每个元素循环次数=总记录数/(元素个数*后续集合的笛卡尔积个数)=12/(2*1)=6次,每个元素每次循环打印次数:后续集合的笛卡尔积个数=1个

*

* 运行结果:

* [[1, 2, 3], [5, 6], [7, 8]]

1,5,7,

1,5,8,

1,6,7,

1,6,8,

2,5,7,

2,5,8,

2,6,7,

2,6,8,

3,5,7,

3,5,8,

3,6,7,

3,6,8]

从结果中可以看到:

a中的每个元素每个元素循环1次,每次打印4个

b中的每个元素每个元素循环3次,每次打印2个

c中的每个元素每个元素循环6次,每次打印1个

*

* @param args

*/

public static void main(String[] args) {

// TODO Auto-generated method stub

String str ="1,3,6,7==4,5,8,9==3,4==43,45,8,9==35,4";

List result = descartes(str);

System.out.println(result);

}

@SuppressWarnings("rawtypes")

public static List descartes(String str) {

String[] list = str.split("==");

List strs = new ArrayList();

for(int i=0;i

strs.add(Arrays.asList(list[i].split(",")));

}

System.out.println(strs);

int total = 1;

for(int i=0;i

total*=strs.get(i).size();

}

String[] mysesult = new String[total];

int now = 1;

//每个元素每次循环打印个数

int itemLoopNum = 1;

//每个元素循环的总次数

int loopPerItem =1;

for(int i=0;i

List temp = strs.get(i);

now = now*temp.size();

//目标数组的索引值

int index=0;

int currentSize = temp.size();

itemLoopNum = total/now;

loopPerItem = total/(itemLoopNum*currentSize);

int myindex = 0;

for(int j=0;j

//每个元素循环的总次数

for(int k=0;k

if(myindex==temp.size())

myindex=0;

//每个元素每次循环打印个数

for(int m=0;m

mysesult[index]=(mysesult[index]==null?"":mysesult[index]+",")+((String)temp.get(myindex));

index++;

}

myindex++;

}

}

}

return Arrays.asList(mysesult);

}

}

运行结果输出:

[[1, 3, 6, 7], [4, 5, 8, 9], [3, 4], [43, 45, 8, 9], [35, 4]]

[1,4,3,43,35, 1,4,3,43,4, 1,4,3,45,35, 1,4,3,45,4, 1,4,3,8,35, 1,4,3,8,4, 1,4,3,9,35, 1,4,3,9,4, 1,4,4,43,35, 1,4,4,43,4, 1,4,4,45,35, 1,4,4,45,4, 1,4,4,8,35, 1,4,4,8,4, 1,4,4,9,35, 1,4,4,9,4, 1,5,3,43,35, 1,5,3,43,4, 1,5,3,45,35, 1,5,3,45,4, 1,5,3,8,35, 1,5,3,8,4, 1,5,3,9,35, 1,5,3,9,4, 1,5,4,43,35, 1,5,4,43,4, 1,5,4,45,35, 1,5,4,45,4, 1,5,4,8,35, 1,5,4,8,4, 1,5,4,9,35, 1,5,4,9,4, 1,8,3,43,35, 1,8,3,43,4, 1,8,3,45,35, 1,8,3,45,4, 1,8,3,8,35, 1,8,3,8,4, 1,8,3,9,35, 1,8,3,9,4, 1,8,4,43,35, 1,8,4,43,4, 1,8,4,45,35, 1,8,4,45,4, 1,8,4,8,35, 1,8,4,8,4, 1,8,4,9,35, 1,8,4,9,4, 1,9,3,43,35, 1,9,3,43,4, 1,9,3,45,35, 1,9,3,45,4, 1,9,3,8,35, 1,9,3,8,4, 1,9,3,9,35, 1,9,3,9,4, 1,9,4,43,35, 1,9,4,43,4, 1,9,4,45,35, 1,9,4,45,4, 1,9,4,8,35, 1,9,4,8,4, 1,9,4,9,35, 1,9,4,9,4, 3,4,3,43,35, 3,4,3,43,4, 3,4,3,45,35, 3,4,3,45,4, 3,4,3,8,35, 3,4,3,8,4, 3,4,3,9,35, 3,4,3,9,4, 3,4,4,43,35, 3,4,4,43,4, 3,4,4,45,35, 3,4,4,45,4, 3,4,4,8,35, 3,4,4,8,4, 3,4,4,9,35, 3,4,4,9,4, 3,5,3,43,35, 3,5,3,43,4, 3,5,3,45,35, 3,5,3,45,4, 3,5,3,8,35, 3,5,3,8,4, 3,5,3,9,35, 3,5,3,9,4, 3,5,4,43,35, 3,5,4,43,4, 3,5,4,45,35, 3,5,4,45,4, 3,5,4,8,35, 3,5,4,8,4, 3,5,4,9,35, 3,5,4,9,4, 3,8,3,43,35, 3,8,3,43,4, 3,8,3,45,35, 3,8,3,45,4, 3,8,3,8,35, 3,8,3,8,4, 3,8,3,9,35, 3,8,3,9,4, 3,8,4,43,35, 3,8,4,43,4, 3,8,4,45,35, 3,8,4,45,4, 3,8,4,8,35, 3,8,4,8,4, 3,8,4,9,35, 3,8,4,9,4, 3,9,3,43,35, 3,9,3,43,4, 3,9,3,45,35, 3,9,3,45,4, 3,9,3,8,35, 3,9,3,8,4, 3,9,3,9,35, 3,9,3,9,4, 3,9,4,43,35, 3,9,4,43,4, 3,9,4,45,35, 3,9,4,45,4, 3,9,4,8,35, 3,9,4,8,4, 3,9,4,9,35, 3,9,4,9,4, 6,4,3,43,35, 6,4,3,43,4, 6,4,3,45,35, 6,4,3,45,4, 6,4,3,8,35, 6,4,3,8,4, 6,4,3,9,35, 6,4,3,9,4, 6,4,4,43,35, 6,4,4,43,4, 6,4,4,45,35, 6,4,4,45,4, 6,4,4,8,35, 6,4,4,8,4, 6,4,4,9,35, 6,4,4,9,4, 6,5,3,43,35, 6,5,3,43,4, 6,5,3,45,35, 6,5,3,45,4, 6,5,3,8,35, 6,5,3,8,4, 6,5,3,9,35, 6,5,3,9,4, 6,5,4,43,35, 6,5,4,43,4, 6,5,4,45,35, 6,5,4,45,4, 6,5,4,8,35, 6,5,4,8,4, 6,5,4,9,35, 6,5,4,9,4, 6,8,3,43,35, 6,8,3,43,4, 6,8,3,45,35, 6,8,3,45,4, 6,8,3,8,35, 6,8,3,8,4, 6,8,3,9,35, 6,8,3,9,4, 6,8,4,43,35, 6,8,4,43,4, 6,8,4,45,35, 6,8,4,45,4, 6,8,4,8,35, 6,8,4,8,4, 6,8,4,9,35, 6,8,4,9,4, 6,9,3,43,35, 6,9,3,43,4, 6,9,3,45,35, 6,9,3,45,4, 6,9,3,8,35, 6,9,3,8,4, 6,9,3,9,35, 6,9,3,9,4, 6,9,4,43,35, 6,9,4,43,4, 6,9,4,45,35, 6,9,4,45,4, 6,9,4,8,35, 6,9,4,8,4, 6,9,4,9,35, 6,9,4,9,4, 7,4,3,43,35, 7,4,3,43,4, 7,4,3,45,35, 7,4,3,45,4, 7,4,3,8,35, 7,4,3,8,4, 7,4,3,9,35, 7,4,3,9,4, 7,4,4,43,35, 7,4,4,43,4, 7,4,4,45,35, 7,4,4,45,4, 7,4,4,8,35, 7,4,4,8,4, 7,4,4,9,35, 7,4,4,9,4, 7,5,3,43,35, 7,5,3,43,4, 7,5,3,45,35, 7,5,3,45,4, 7,5,3,8,35, 7,5,3,8,4, 7,5,3,9,35, 7,5,3,9,4, 7,5,4,43,35, 7,5,4,43,4, 7,5,4,45,35, 7,5,4,45,4, 7,5,4,8,35, 7,5,4,8,4, 7,5,4,9,35, 7,5,4,9,4, 7,8,3,43,35, 7,8,3,43,4, 7,8,3,45,35, 7,8,3,45,4, 7,8,3,8,35, 7,8,3,8,4, 7,8,3,9,35, 7,8,3,9,4, 7,8,4,43,35, 7,8,4,43,4, 7,8,4,45,35, 7,8,4,45,4, 7,8,4,8,35, 7,8,4,8,4, 7,8,4,9,35, 7,8,4,9,4, 7,9,3,43,35, 7,9,3,43,4, 7,9,3,45,35, 7,9,3,45,4, 7,9,3,8,35, 7,9,3,8,4, 7,9,3,9,35, 7,9,3,9,4, 7,9,4,43,35, 7,9,4,43,4, 7,9,4,45,35, 7,9,4,45,4, 7,9,4,8,35, 7,9,4,8,4, 7,9,4,9,35, 7,9,4,9,4]

递归算法:

public static void fn(List list,String[] arr,String str){

//迭代list

List li = new ArrayList();

for(int i=0;i

//取得当前的数组

if(i==list.indexOf(arr)){

//迭代数组

System.out.println(arr.length);

for(String st : arr){

st = str + st;

if(i

fn(list,list.get(i+1),st);

}else if(i==list.size()-1){

li.add(st);

}

}

}

}

for(int i = 0 ; i < li.size();i++ )

{

System.out.println(li.get(i));

}

}

希望本文所述对大家java程序设计有所帮助。

java 笛卡尔积_Java笛卡尔积算法原理与实现方法详解相关推荐

  1. Java语言求笛卡尔积,Java笛卡尔积算法原理与实现方法详解

    本文实例讲述了Java笛卡尔积算法原理与实现方法.分享给大家供大家参考,具体如下: 笛卡尔积算法的Java实现: (1)循环内,每次只有一列向下移一个单元格,就是CounterIndex指向的那列. ...

  2. java 方法继承方法_java的继承原理与实现方法详解

    本文实例讲述了java的继承原理与实现方法.分享给大家供大家参考,具体如下: 继承 1.java中是单继承的.每个子类只有一个父类. 语法:子类 extends 父类 2.在java中,即使没有声明父 ...

  3. java 使用apollo,Springboot apollo原理及使用方法详解

    文章背景 如果在spring boot中接入apollo官方文档:使用官方的apollo 演示环境(demo): 106.54.227.205账号/密码:apollo/admin 添加配置 sprin ...

  4. java函数式编程归约reduce概念原理 stream reduce方法详解 reduce三个参数的reduce方法如何使用

    java函数式编程归约reduce概念原理 stream reduce方法详解 reduce三个参数的reduce方法如何使用

  5. python创建双链表_Python双链表原理与实现方法详解

    本文实例讲述了Python双链表原理与实现方法.分享给大家供大家参考,具体如下: Python实现双链表 文章目录 Python实现双链表 单链表与双链表比较 双链表的实现 定义链表节点 初始化双链表 ...

  6. java调用javascript函数_[Java教程]JavaScript函数的4种调用方法详解

    [Java教程]JavaScript函数的4种调用方法详解 0 2016-08-09 00:00:12 在JavaScript中,函数是一等公民,函数在JavaScript中是一个数据类型,而非像C# ...

  7. java 三种将list转换为map的方法详解

    这篇文章主要介绍了java 三种将list转换为map的方法详解的相关资料,需要的朋友可以参考下 java 三种将list转换为map的方法详解 在本文中,介绍三种将list转换为map的方法: 1) ...

  8. mysql 账户管理_Mysql账户管理原理与实现方法详解

    本文实例讲述了Mysql账户管理原理与实现方法.分享给大家供大家参考,具体如下: 账户管理 在生产环境下操作数据库时,绝对不可以使用root账户连接,而是创建特定的账户,授予这个账户特定的操作权限,然 ...

  9. 光纤收发器的原理及应用_光纤收发器的工作原理以及使用方法详解!

    原标题:光纤收发器的工作原理以及使用方法详解! 关于光纤收发器的工作原理以及使用方法这块,在这里飞畅科技的小编做了专门的整理,首先,我们来了解下什么是光纤收发器,光纤收发器是一种将短距离的双绞线电信号 ...

最新文章

  1. 2022-2028年中国服装行业分析报告-产业规模现状与发展规划趋势
  2. Windows 配置 Github 的 SSH-key
  3. 用PaddlePaddle(飞桨)实现minist数据集的GAN生成
  4. Java log4j使用
  5. Java 学习笔记之 Synchronized锁重入
  6. 网络克隆安装linux系统下载安装,pxe网刻工具_诚龙网刻教程_网络克隆安装windows7...
  7. 算法精解----3、单链表
  8. RHCSA-Day1 --- Linux介绍及环境搭建
  9. 会议会展产业要善用信息技术提高活动运营管理效率
  10. 这一次带你彻底了解远程Cookie操作
  11. web编程1–用户注册之文本框应用,coon连接,存入mysql
  12. 方舟生存进化服务器信息错误,方舟生存进化网络错误信息怎么办
  13. 计算机基础知识测试1,计算机基础知识测试试题及答案(网络)1
  14. linux开机启动项怎么设置bios,bios怎么设置开机启动项
  15. python 猴子偷桃问题
  16. 那些年微信开发过的鸡肋功能,及其带给我们的思考
  17. C++11特性(详细版)
  18. 超市管理系统-2(数据库代码以及数据库逻辑)
  19. wow Onyxia
  20. PTA 空心字母金字塔+数字金字塔+字母金字塔

热门文章

  1. 理解EnterCriticalSection 临界区
  2. 【reversing.kr逆向之旅】Position的writeup
  3. 浅谈草根站长要怎么在互联网奋斗
  4. English Word —— Day 38——四级中学已学单词表
  5. python基础:字符串的join()函数使用
  6. 电脑网络连接受限的解决方法
  7. Win7 C盘空间越来越小、使用空间不够?教你如何清理C盘
  8. 孩子父亲表示法表示树
  9. 运维工程师需要掌握的基础技能有哪些?
  10. 变电站综合自动化系统