JavaScript算法系列之

Stella981
• 阅读 504

1.输入一个字符串,按字典序打印出该字符串中字符的所有排列。例如输入字符串abc,则打印出由字符a,b,c所能排列出来的所有字符串abc,acb,bac,bca,cab和cba

字符串拼接

(先理解不输入重复字符的)

 1 function permutate(str) {
 2     var result=[];
 3     if(str.length==1){
 4         return [str]    
 5     }else{  
 6         var preResult=permutate(str.slice(1));
 7         for (var j = 0; j < preResult.length; j++) {
 8             for (var k = 0; k < preResult[j].length+1; k++) {
 9                 var temp=preResult[j].slice(0,k)+str[0]+preResult[j].slice(k);   
10                 result.push(temp);              
11             }
12         }
13         return result;
14     }  
15 }
16 console.log(permutate("abc"));

上述方式不是用交换实现的 用的是字符串拼接的方法

原理:

固定第一个字符,递归取得第一个字符后面的各种字符串组合;

再把第一个字符与后面每一个字符交换,并同样递归获得收尾后面的字符串组合;

递归的出口为当只有一个字符的时候

理解的不用看一下算法流程了!

=============================================================================================================

假设输入abc

大概走一遍算法执行流程

第一步 str='abc';

第二步 到6行 preResult='bc' 递归

第三步 到6行  preResult='c' 递归

第四步 到第四行返回 [c]  此时回到第三步的递归 str = 'bc' 执行第7行往下的循环

循环完毕后result=['bc','cb'] 此时返回第二步的递归 str='abc' 执行7行往下的循环

第五步 循环完毕后result=['abc','bac','bca','acb','cab','cba'] 此时输出最终结果

 ============================================================================================================

字符串交换

 1 function permutation(str){
 2     let result = [];
 3     if(str.length === 1){
 4         return [str];
 5     }else{
 6         let last = permutation(str.slice(1));
 7         for(let i=0; i<last.length;i++){
 8             let ss = swap(str[0],last[i],result);
 9             result=ss;
10         }
11         return result;
12     }
13 }
14 function swap(a,b,result){
15     for(let i=0;i<b.length+1;i++){
16         let newStr = b;
17         let sss = newStr.split('');
18         sss.splice(i,0,a); 
19         result.push(sss.join(''))      
20     }
21     return result;
22 }
23 
24 let res = permutation('abc');
25 console.log(res);

对于有重复的字符串来说按照上述算法输出出来会有重复的组合,偷懒的解法是直接去重就可以了

加一句Array.from(new Set(permutate("abc")));

点赞
收藏
评论区
推荐文章
blmius blmius
2年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Karen110 Karen110
2年前
一篇文章带你了解JavaScript日期
日期对象允许您使用日期(年、月、日、小时、分钟、秒和毫秒)。一、JavaScript的日期格式一个JavaScript日期可以写为一个字符串:ThuFeb02201909:59:51GMT0800(中国标准时间)或者是一个数字:1486000791164写数字的日期,指定的毫秒数自1970年1月1日00:00:00到现在。1\.显示日期使用
Wesley13 Wesley13
2年前
java将前端的json数组字符串转换为列表
记录下在前端通过ajax提交了一个json数组的字符串,在后端如何转换为列表。前端数据转化与请求varcontracts{id:'1',name:'yanggb合同1'},{id:'2',name:'yanggb合同2'},{id:'3',name:'yang
DaLongggggg DaLongggggg
3年前
python百题大冲关-确定字符串是否是另一个的排列
挑战介绍实现一个算法来识别一个字符串str2是否是另一个字符串str1的排列。排列的解释如下:如果将str1的字符拆分开,重新排列后再拼接起来,能够得到str2,那么就说字符串str2是字符串str1的排列。本次挑战中,你需要在permutation.py文件中补充函数is_permutation的空缺部分
Easter79 Easter79
2年前
SpringBoot自定义序列化的使用方式
场景及需求:项目接入了SpringBoot开发,现在需求是服务端接口返回的字段如果为空,那么自动转为空字符串。例如:\    {        "id":1,        "name":null    },    {        "id":2,        "name":"x
Stella981 Stella981
2年前
JS 苹果手机日期显示NaN问题
问题描述newDate("2019122910:30:00")在IOS下显示为NaN原因分析带的日期IOS下存在兼容问题解决方法字符串替换letdateStr"2019122910:30:00";datedateStr.repl
Stella981 Stella981
2年前
JavaScript常用函数
1\.字符串长度截取functioncutstr(str,len){vartemp,icount0,patrn/^\x00\xff/,strre"";for(vari
Wesley13 Wesley13
2年前
unity将 -u4E00 这种 编码 转汉字 方法
 unity中直接使用 JsonMapper.ToJson(对象),取到的字符串,里面汉字可能是\\u4E00类似这种其实也不用转,服务器会通过类似fastjson发序列化的方式,将json转对象,获取对象的值就是中文但是有时服务器要求将传参中字符串中类似\\u4E00这种转汉字,就需要下面 publ
Stella981 Stella981
2年前
SpringBoot自定义序列化的使用方式
场景及需求:项目接入了SpringBoot开发,现在需求是服务端接口返回的字段如果为空,那么自动转为空字符串。例如:\    {        "id":1,        "name":null    },    {        "id":2,        "name":"x
京东云开发者 京东云开发者
7个月前
分布式系统的主键生成方案对比 | 京东云技术团队
UUID​UUID(通用唯一识别码)是由32个十六进制数组成的无序字符串,通过一定的算法计算出来。为了保证其唯一性,UUID规范定义了包括网卡MAC地址、时间戳、名字空间(Namespace)、随机或伪随机数、时序等元素,以及从这些元素生成UUID的算法。