首页 > web前端 > js教程 > JavaScript趣题:全排列去重

JavaScript趣题:全排列去重

黄舟
发布: 2017-01-22 14:42:55
原创
1851 人浏览过

给定一个字符串,将它所有的全排列结果以数组的形式展示,要求没有重复的结果。

举个例子:

我有字符串”aabb”,它的全排列结果应该有4*3*2*1=24种,但是考虑到要求为没有重复,所以结果为6种,如下所示:

['aabb', 'abab', 'abba', 'baab', 'baba', 'bbaa']

所以问题的关键在于2个方面:

1.如何求全排列

2.如何对结果去重

求全排列,既可以用递归,也可以用非递归方法。

去重可以使用一个hash来达到目的。

//递归求解全排列  
function permutations(string) {  
    //用于存放去重结果的hash  
    var hash = {};  
    //遍历函数  
    //from:要遍历的字符数组  
    //to:记录路径的字符数组  
    var traverse = function(from,to){  
        //若当前深度没有达到叶子  
        if(to.length < string.length){  
            for(var i=0;i<from.length;i++){  
                var newFrom = from.slice(0);  
                var one = newFrom.splice(i,1);  
                var newTo = to.slice(0);  
                newTo = newTo.concat(one);  
                traverse(newFrom,newTo);  
            }  
        }  
        else{  
            //作为key存入hash  
            hash[to.join("")] = null;  
        }  
    };  
      
    traverse(string.split(""),[]);  
    //提取hash的key作为数组返回  
    return Object.keys(hash);  
}
登录后复制

以上就是 JavaScript趣题:全排列去重的内容,更多相关内容请关注PHP中文网(www.php.cn)!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板