标准的排序组合-算法

题目

有若干个字母,要求计算出长度为4的所有可能得组合

解题

排序组合最适用的就是回溯了,建议大家本地debug一层一层的看能好理解点

复制代码
private static void getResult(List<String> source, Stack<String> temp, int curLength, int maxLength, List<Stack<String>> result) {
    if (curLength == maxLength) {
      result.add((Stack<String>) temp.clone());
      return;
    }
    for (int i = 0; i < source.size(); i++) {
      if (temp.contains(source.get(i))) {
        continue;
      }
      temp.push(source.get(i));
      getResult(source, temp, curLength + 1, maxLength, result);
      temp.pop();
    }
  }

回溯之所以叫回溯,就是因为他是从尾巴的地方先遍历所有的可能性,然后再往上一层,当然了上一层遍历时还需要再往下一层检查所有的可能性

相关推荐
文艺倾年9 分钟前
【免训练&测试时扩展】通过任务算术转移思维链能力
人工智能·分布式·算法
curry____30320 分钟前
dfs全排列和全组合问题
算法·深度优先
想做功的洛伦兹力11 小时前
2026/2/12日打卡
开发语言·c++·算法
大模型玩家七七1 小时前
技术抉择:微调还是 RAG?——以春节祝福生成为例
android·java·大数据·开发语言·人工智能·算法·安全
你撅嘴真丑1 小时前
蛇形填充数组 与 查找最接近的元素
数据结构·c++·算法
JXL18601 小时前
Dynamic programming
算法
blackicexs1 小时前
第四周第四天
数据结构·c++·算法
TracyCoder1231 小时前
LeetCode Hot100(46/100)——74. 搜索二维矩阵
算法·leetcode·矩阵
foundbug9991 小时前
果蝇优化算法(FOA)详解:原理、实现与应用
算法
游乐码1 小时前
c#递归函数
算法·c#