java笛卡尔积算法_Java 笛卡尔积算法的简单实现

java笛卡尔积算法_Java 笛卡尔积算法的简单实现笛卡尔积算法的Java实现:(1)循环内,每次只有一列向下移一个单元格,就是CounterIndex指向的那列。(2)如果该列到尾部了,则这列index重置为0,而CounterIndex则指向前一列,相当于进位,把前列的index加一。(3)最后,由生成的行数来控制退出循环。publicclassTest{privatestaticString[]aa={“aa1”,”aa2…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

笛卡尔积算法的Java实现:

6eb05952d109085b2fee3cc7d9bc66e0.png

(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);

}

}

——————————————————————————————————————————-

递归:

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));

}

}

b52d16ffc81ddc5a9ee1c28b97059900.png

大小: 16.8 KB

分享到:

18e900b8666ce6f233d25ec02f95ee59.png

72dd548719f0ace4d5f9bca64e1d7715.png

2012-10-31 15:26

浏览 7889

评论

1 楼

yujiaao

2017-08-25

fn 函数循环是没有必要的啊,可以改成

protected static List fn(List list, Object[] arr, String result, String separator) {

//迭代list

List li = new ArrayList();

//取得当前的数组

int i = list.indexOf(arr);

//迭代数组

for (Object st : arr) {

if (StringUtils.isNotBlank(result)) {

st = result + separator + st;

}

if (i < list.size() – 1) {

li.addAll(fn(list, list.get(i + 1), st.toString(), separator));

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

li.add(st.toString());

}

}

return li;

}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/157687.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 深入浅出Yolo系列之Yolov3&Yolov4&Yolov5&Yolox核心基础知识完整讲解

    深入浅出Yolo系列之Yolov3&Yolov4&Yolov5&Yolox核心基础知识完整讲解因为工作原因,项目中经常遇到目标检测的任务,因此对目标检测算法会经常使用和关注,比如Yolov3、Yolov4算法。当然,实际项目中很多的第一步,也都是先进行目标检测任务,比如人脸识别、多目标追踪、REID、客流统计等项目。因此目标检测是计算机视觉项目中非常重要的一部分。从2018年Yolov3年提出的两年后,在原作者声名放弃更新Yolo算法后,俄罗斯的Alexey大神扛起了Yolov4的大旗。在此,大白将项目中,需要了解的Yolov3、Yolov4系列相关知识点以及相关代码进行完整的汇总,希望和大家

    2022年6月12日
    56
  • pycharm实用快捷键注释大全(持续更新中)

    pycharm实用快捷键注释大全(持续更新中)Ctrl F1 显示错误描述或警告信息 Alt Enter 快速修正 Ctrl R 替换 Ctrl Shift F 或者连续 2 次敲击 shift 全局查找 可以在整个项目中查找某个字符串什么的 如查找某个函数名字符串看之前是怎么使用这个函数的 Ctrl Shift R 全局替换 Alt Shift F10 运行模式配置 Alt

    2025年7月3日
    0
  • java如何验证手机号码_Java 手机号码正则表达式验证「建议收藏」

    java如何验证手机号码_Java 手机号码正则表达式验证「建议收藏」1.正则表达式的字符串表示StringmobileRegex=”^1(3|4|5|7|8)\\d{9}$”;字符^意义:表示匹配的字符必须在最前边;字符$意义:表示待匹配串的结束位置;字符\d{5,9}意义:\d是数字,{5,9}是5-9位,如果只是验证手机号,且校验的正则表达式如下:/^1[3|5|8][0-9]\d{4,8}$/;不妨写成/^1[3|5|8]\…

    2022年5月20日
    196
  • mysql字符串截取函数_excel 截取部分字符

    mysql字符串截取函数_excel 截取部分字符MySQL 字符串截取函数:left(), right(), substring(), substring_index()。还有 mid(), substr()。其中,mid(), substr() 等价于 substring() 函数,substring() 的功能非常强大和灵活。  1. 字符串截取:left(str, length)  mysql> select left(‘sqls

    2022年10月2日
    0
  • How AHI Fintech and DataVisor are Securing Data through AI and Big Data

    How AHI Fintech and DataVisor are Securing Data through AI and Big Data

    2022年4月2日
    46
  • 机器学习之文本分类(附带训练集+数据集+所有代码)

    机器学习之文本分类(附带训练集+数据集+所有代码)我本次对4类文本进行分类((所有截图代码和数据集最后附带免费下载地址))主要步骤:1.各种读文件,写文件2.使用jieba分词将中文文本切割3.对处理之后的文本开始用TF-IDF算法进行单词权值的计算4.去掉停用词5.贝叶斯预测种类文本预处理:除去噪声,如:格式转换,去掉符号,整体规范化遍历的读取一个文件下的每个文本中文分词…

    2022年6月2日
    23

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号