function fullSort(arr){
if(typeof arr === 'String'){
arr=arr.split('')
}
function printArr(arr){
var result = [];
if (arr.length === 1) {
result.push(arr);
return result;
}
for (var i = 0; i < arr.length; i++) {
var temp = [];
temp.push(arr[i]); //取任意一项放到temp的第一项
var remain = arr.slice(0);//复制原数组到remain
remain.splice(i,1); //去掉那一项
var temp2 = printArr(remain).concat(); //剩下的项全排列,返回[[1,2],[1,3]]这样的数据
for (var j = 0; j < temp2.length; j++) {
temp2[j].unshift(temp[0]); // [[5,1,2],[5,1,3]]这样的数据
result.push(temp2[j]);
}
}
return result
}
return Array.from(new Set(printArr(arr).map(i=>i.join('')))) //去重 件里面数组改为字符串
}
全排列
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。