笛卡尔积算法「建议收藏」

笛卡尔积算法「建议收藏」/***生成笛卡尔积*@paramdimvalue*@paramresult*@paramlayer*@paramcurList*/privatestaticvoiddescartes(List

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

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

/** * 生成笛卡尔积 * @param dimvalue * @param result * @param layer * @param curList */
private static void descartes(List<List<String>> dimvalue, List<List<String>> result, int layer, List<String> curList) { 

if (layer < dimvalue.size() - 1) { 

if (dimvalue.get(layer).size() == 0) { 

descartes(dimvalue, result, layer + 1, curList);
} else { 

for (int i = 0; i < dimvalue.get(layer).size(); i++) { 

List<String> list = new ArrayList<>(curList);
list.add(dimvalue.get(layer).get(i));
descartes(dimvalue, result, layer + 1, list);
}
}
} else if (layer == dimvalue.size() - 1) { 

if (dimvalue.get(layer).size() == 0) { 

result.add(curList);
} else { 

for (int i = 0; i < dimvalue.get(layer).size(); i++) { 

List<String> list = new ArrayList<>(curList);
list.add(dimvalue.get(layer).get(i));
result.add(list);
}
}
}
}
/** * 调用生成列表 * @param list * @return */
public static List<String> result(List<List<String>> list){ 

List<List<String>> result = new ArrayList<>();
descartes(list, result, 0, new ArrayList<>());
//重组数据
List<String> data=new ArrayList<>();
result.forEach(oList->{ 

StringBuilder sb=new StringBuilder();
for(int i=0;i<oList.size();i++){ 

sb.append(oList.get(i));
if(i!=oList.size()-1){ 

sb.append(",");
}
}
data.add(sb.toString());
});
return data;
}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/157421.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

发表回复

您的电子邮箱地址不会被公开。

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