js全排列组合算法(基于递归回溯)

function permute(nums) {

let result = \[\]; // 存放结果的数组

function backtracking(tempList, nums) {

if (nums.length === 0) {

result.push(...tempList); // 将当前路径添加到结果数组中

return;

}

for (let i = 0; i < nums.length; i++) {

tempList.push(numsi); // 选取当前元素并添加到临时列表中

const remainingNums = ...nums; // 复制原始数组作为新的子集

remainingNums.splice(i, 1); // 移除已经处理过的元素

backtracking(tempList, remainingNums); // 进入下一层递归

tempList.pop(); // 回溯,从临时列表中删除最后一个元素

}

}

backtracking(\[\], nums); // 调用递归函数开始计算所有排列组合

return result;

}

// 示例输入

const inputArray = 1, 2, 3;

console.log(permute(inputArray));

相关推荐
集成显卡4 小时前
Rust实战七 |基于带 colored 颜色文字控制台的批量文件删除工具
开发语言·后端·rust
梦想的颜色4 小时前
TypeScript 完全指南(下):从类型体操到生产级配置
前端·javascript·typescript
比昨天多敲两行4 小时前
linux 线程概念与控制
java·开发语言·jvm
huaweichenai5 小时前
php 根据每个类型的抽签范围实现抽签功能
开发语言·php
8Qi85 小时前
LeetCode 75:颜色分类(荷兰国旗问题)—— Java 题解 ✅
java·算法·leetcode·指针·排序
codeejun6 小时前
每日一Go-73、云原生成本优化 —— 资源限制 & 指标驱动扩容
开发语言·云原生·golang
888CC++6 小时前
如何在 C 语言中进行程序调试?
前端·javascript·算法
就叫_这个吧6 小时前
Java注解、元注解、自定义注解定义及应用
java·开发语言·注解
Sam_Deep_Thinking7 小时前
聊聊Java中的of
java·开发语言·架构