求多数组的排列组合算法...

发布于 2022-09-01 05:21:42 字数 140 浏览 14 评论 0

有多个数组, 比如:
{a,b,c,d}
{1,2}
{g}
{q,w,e}
想分别从每个数组中取出一个值, 然后组合.({a,1,g,q} {a,2,g,q}... ...)
怎么样才能把所有的情况都组合起来呢?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

巾帼英雄 2022-09-08 05:21:42

递归

public List<String> permutation(List<String> inputList){
    List<String> resList = new ArrayList<>();
    permutationInt(inputList, resList, 0, 
            new char[inputList.size()]);
    return resList;
}



private void permutationInt(List<String> inputList, List<String> resList,
        int ind, char[] arr) {
    if(ind == inputList.size()){
        resList.add(new String(arr));
        return;
    }

    for(char c: inputList.get(ind).toCharArray()){
        arr[ind] = c;
        permutationInt(inputList, resList, ind + 1, arr);
    } 
}
蓝颜夕 2022-09-08 05:21:42

我知道你问的是java的,不过我给个python的,python 比较方便 嘿嘿,java的原理是一样的

L1=['a','b','c','d']
L2=['1','2']
L3=['g']
L4=['q','w','e']
list = [[i,j,k,p] for i in L1 for j in L2 for k in L3 for p in L4]

补充回答:不确定几个list,不确定list多长的时候

#把取来的数组合成一个大list,然后再一行代码就没有然后了
s=[ ['a','b','c','d'], ['1','2'], ['g'],['q','w','e'] ]
list = list(itertools.product(*s))
我爱人 2022-09-08 05:21:42

记录每个数组的当前元素下标。
问题中的例子为例:
[0, 0, 0, 0]
[0, 0, 0, 1]
[0, 0, 0, 2]
最后一个走到头了,于是他的前一个加1,自己自觉退到0,
这时发现{g}也到头了,于是他的前一个(假设为i)加1,i之后的都统统清零:
[0, 1, 0, 0]
[0, 1, 0, 1]
...
直到第一个数也走到头。

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文