java - 递归而不是多循环

标签 java recursion loops combinatorics

我希望这个方法适用于任何给定数量的参数,我可以通过代码生成来做到这一点(有很多丑陋的代码),它可以通过递归来完成吗?如果是这样怎么办?我懂递归,但我不知道怎么写。

private static void allCombinations(List<String>... lists) {
    if (lists.length == 3) {
        for (String s3 : lists[0]) {
            for (String s1 : lists[1]) {
                for (String s2 : lists[2]) {
                    System.out.println(s1 + "-" + s2 + "-" + s3);
                }
            }
        }
    }
    if (lists.length == 2) {
        for (String s3 : lists[0]) {
            for (String s1 : lists[1]) {
                    System.out.println(s1 + "-" + s3);
            }
        }
    }
}

最佳答案

这是一个简单的递归实现:

private static void allCombinations(List<String>... lists) {
  allCombinations(lists, 0, "");
}

private static void allCombinations(List<String>[] lists, int index, String pre) {
  for (String s : lists[index]) {
    if (index < lists.length - 1) {
      allCombinations(lists, index + 1, pre + s + "-");
    }else{
      System.out.println(pre + s);
    }
  }
}

关于java - 递归而不是多循环,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/207889/

相关文章:

java - 如何用java编写中值滤波器?

java - 通过java代码自动化在Outlook中添加约会事件

javac错误: Class names are only accepted if annotation processing is explicitly requested

algorithm - 优化递归序列的计算

WordPress 循环 - 如何计算项目数

java - 如何在 android 中将蓝牙设备发现超时设置为 1 小时(3600)秒并且从不超时

function - OCaml - 将递归函数的值保存在哈希表中

algorithm - 如果在递归堆栈中找到顶点,则在有向图中检测到循环 - 为什么?

python - python中的映射和循环

loops - 每个循环的 SCSS 具有带十进制值的多个变量