数组排列组合

发布于 2023-05-04 19:15:28 字数 634 浏览 63 评论 0

求集合单词组合起来的不同结果,集合中的单词不重复,每个结果包含所有单词,给定一个 包含单词的数组,求排列组合

function permute(arr) {
    if (arr.length === 0) {
      return [[]];
    }
    let result = [];
    for (let i = 0; i < arr.length; i++) {
      let rest = [...arr.slice(0, i), ...arr.slice(i + 1)];
      // 取出剩下元素排列组合
      let subResult = permute(rest);
      for (let j = 0; j < subResult.length; j++) {
        result.push([arr[i], ...subResult[j]]);
      }
    }
    return result.map(item => item.join(''))
  }

  const arr = ['foo','bar','hello','world']
  permute(arr)

通过递归的方式 获取 所有的排列情况,每个循环都取一个元素作为首位,剩下的元素排列组合,剩下的元素重复这个逻辑。实现了阶乘的逻辑。

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

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

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据

关于作者

贱贱哒

暂无简介

0 文章
0 评论
521 人气
更多

推荐作者

qq_eQNo9e

文章 0 评论 0

内心旳酸楚

文章 0 评论 0

mb_BlPo2I8v

文章 0 评论 0

alipaysp_ZRaVhH1Dn

文章 0 评论 0

alipaysp_VP2a8Q4rgx

文章 0 评论 0

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