js-FCC算法-No repeats please字符串的全排列(详解)


Posted in Javascript onMay 02, 2017

把一个字符串中的字符重新排列生成新的字符串,返回新生成的字符串里没有连续重复字符的字符串个数.连续重复只以单个字符为准

例如, aab 应该返回 2 因为它总共有6中排列 (aab, aab, aba, aba, baa, baa),但是只有两个 (aba and aba)没有连续重复的字符 (在本例中是 a).

从网上资料获得了一些思路,我的代码:

function permAlone(str) {
 var arr=str.split("");
 var perarr=[];
 var begin=0;
 //创建正则,如果字符串全重复,则直接return 0
 var reg = /(.)\1+/g;
 if(str.match(reg)!==null&&str.match(reg)[0]===str){
  return 0;
 }
 //用于交换的函数
 function swap(idx1,idx2){
   var temp=arr[idx1];
   arr[idx1]=arr[idx2];
   arr[idx2]=temp;
 }
 //如果begin到了最后一个字符,可以将这个字符串加入到全排列数组中了
 function permall(arr,begin){
  if(begin==arr.length-1){
   perarr[perarr.length]=arr.join("");
   return;
  }
  for(var i=0;(i+begin)<arr.length;i++){
   swap(begin,begin+i);
   permall(arr,begin+1);
   swap(begin,begin+i);
  }
 }
 permall(arr,begin);
 //返回相邻不重复的数量
 return perarr.filter(function(val) {
   return !val.match(reg);
 }).length;
}

permAlone('aab');

首先,把第一个字符和其后面的字符一一交换。

接着,固定第一个字符,求后面所有字符的排列。这个时候我们仍把后面的所有字符分成两部分:后面字符的第一个字符,以及这个字符之后的所有字符。然后把第一个字符逐一和它后面的字符交换。

去重的全排列就是从第一个数字起每个数分别与它后面非重复出现的数字交换。

以上这篇js-FCC算法-No repeats please字符串的全排列(详解)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jQuery 图像裁剪插件Jcrop的简单使用
May 22 Javascript
JS实现字体选色板实例代码
Nov 20 Javascript
node.js中的http.response.end方法使用说明
Dec 14 Javascript
javascript结合CSS实现苹果开关按钮特效
Apr 07 Javascript
JavaScript缓冲运动实现方法(2则示例)
Jan 08 Javascript
Bootstrap~多级导航(级联导航)的实现效果【附代码】
Mar 08 Javascript
Vue.js快速入门实例教程
Oct 15 Javascript
原生js实现焦点轮播图效果
Jan 12 Javascript
vue组件与复用详解
Apr 08 Javascript
vue基础知识--axios合并请求和slot
Jun 04 Javascript
原生JS实现无缝轮播图片
Jun 24 Javascript
vuex的数据渲染与修改浅析
Nov 26 Vue.js
详解webpack+es6+angular1.x项目构建
May 02 #Javascript
jQuery Tree Multiselect使用详解
May 02 #jQuery
bootstrap的常用组件和栅格式布局详解
May 02 #Javascript
Vuejs实现带样式的单文件组件新方法
May 02 #Javascript
基于bootstrap实现bootstrap中文网巨幕效果
May 02 #Javascript
老生常谈js-react组件生命周期
May 02 #Javascript
js 用于检测类数组对象的函数方法
May 02 #Javascript
You might like
表单提交错误后返回内容消失问题的解决方法(PHP网站)
2015/10/20 PHP
php实现mysql连接池效果实现代码
2018/01/25 PHP
javascript之水平横向滚动歌词同步的应用
2007/05/07 Javascript
ExtJS 2.0实用简明教程之应用ExtJS
2009/04/29 Javascript
js常用代码段收集
2011/10/28 Javascript
javascript中的self和this用法小结
2014/02/08 Javascript
浅谈Javascript的静态属性和原型属性
2015/05/07 Javascript
javascript中判断json的方法总结
2015/08/27 Javascript
基于jQuery实现自动轮播旋转木马特效
2015/11/02 Javascript
JavaScript File API文件上传预览
2016/02/02 Javascript
原生js实现返回顶部缓冲效果
2017/01/18 Javascript
js鼠标移动时禁止选中文字
2017/02/19 Javascript
使用Bootstrap打造特色进度条效果
2017/05/02 Javascript
vue.js 获取当前自定义属性值
2017/06/01 Javascript
BootStrap数据表格实例代码
2017/09/13 Javascript
Vue2.0父组件与子组件之间的事件发射与接收实例代码
2017/09/19 Javascript
详解Angular路由之路由守卫
2018/05/10 Javascript
JavaScript常用截取字符串的三种方式用法区别实例解析
2018/05/15 Javascript
解决layui弹框失效的问题
2019/09/09 Javascript
javascript中闭包closure的深入讲解
2021/03/03 Javascript
[02:53]2018年度DOTA2最佳战队-完美盛典
2018/12/17 DOTA
python实现比较两段文本不同之处的方法
2015/05/30 Python
Python 安装setuptools和pip工具操作方法(必看)
2017/05/22 Python
简单了解Python中的几种函数
2017/11/03 Python
使用Python+Splinter自动刷新抢12306火车票
2018/01/03 Python
python实现隐马尔科夫模型HMM
2018/03/25 Python
django启动uwsgi报错的解决方法
2018/04/08 Python
Python if语句知识点用法总结
2018/06/10 Python
python实现最速下降法
2020/03/24 Python
使用matplotlib动态刷新指定曲线实例
2020/04/23 Python
高校生生产实习自我鉴定
2013/09/21 职场文书
行政经理的岗位职责
2013/11/23 职场文书
职业生涯规划书前言
2014/04/15 职场文书
机关党员公开承诺书
2014/08/30 职场文书
车辆转让协议书
2014/09/24 职场文书
学校运动会广播稿范文
2014/10/02 职场文书