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 相关文章推荐
javascript编程起步(第五课)
Jan 10 Javascript
使弱类型的语言JavaScript变强势
Jun 22 Javascript
js 获取input点选按钮的值的方法
Apr 14 Javascript
javascript学习笔记(三)BOM和DOM详解
Sep 30 Javascript
HTML,CSS,JavaScript速查表推荐
Dec 02 Javascript
JQuery插件jcarousellite的参数中文说明
May 11 Javascript
基于MVC+EasyUI的web开发框架之使用云打印控件C-Lodop打印页面或套打报关运单信息
Aug 29 Javascript
vue实现某元素吸顶或固定位置显示(监听滚动事件)
Dec 13 Javascript
对vux点击事件的优化详解
Aug 28 Javascript
详解实现一个通用的“划词高亮”在线笔记功能
Apr 23 Javascript
基于Taro的微信小程序模板消息-获取formId功能模块封装实践
Jul 15 Javascript
微信小程序实现日历签到
Sep 21 Javascript
详解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
判“新”函数:得到今天与明天的秒数
2006/10/09 PHP
人脸识别测颜值、测脸龄、测相似度微信接口
2016/04/07 PHP
javascript js cookie的存储,获取和删除
2007/12/29 Javascript
innerhtml用法 innertext用法 以及innerHTML与innertext的区别
2009/10/26 Javascript
返回对象在当前级别中是第几个元素的实现代码
2011/01/20 Javascript
33个优秀的jQuery 教程分享(幻灯片、动画菜单)
2011/07/08 Javascript
document.createElement()用法及注意事项(ff下不兼容)
2013/03/13 Javascript
AngularJS实现Model缓存的方式
2016/02/03 Javascript
AngularJS监听路由的变化示例代码
2016/09/23 Javascript
浅析BootStrap Treeview的简单使用
2016/10/12 Javascript
浅谈js函数中的实例对象、类对象、局部变量(局部函数)
2016/11/20 Javascript
使用JS正则表达式 替换括号,尖括号等
2016/11/29 Javascript
基于JS实现bookstore静态页面的实例代码
2017/02/22 Javascript
javascript+jQuery实现360开机时间显示效果
2017/11/03 jQuery
解决iView中时间控件选择的时间总是少一天的问题
2018/03/15 Javascript
JavaScript中var、let、const区别浅析
2018/06/24 Javascript
详解Vue iview IE浏览器不兼容报错(Iview Bable polyfill)
2019/01/07 Javascript
使用layer模态框给新页面传值的方法
2019/09/27 Javascript
详解Python中for循环是如何工作的
2017/06/30 Python
python实现QQ邮箱/163邮箱的邮件发送
2019/01/22 Python
python3.6环境安装+pip环境配置教程图文详解
2019/06/20 Python
Django Serializer HiddenField隐藏字段实例
2020/03/31 Python
python IDLE添加行号显示教程
2020/04/25 Python
python 通过文件夹导入包的操作
2020/06/01 Python
python 带时区的日期格式化操作
2020/10/23 Python
简历的自我评价范文
2014/02/04 职场文书
文明家庭先进事迹材料
2014/05/14 职场文书
企业党员一句话承诺
2014/05/30 职场文书
医学专业大学生求职信
2014/07/12 职场文书
小学四年级学生评语
2014/12/26 职场文书
学习保证书怎么写
2015/02/26 职场文书
2019年恭贺升学祝福语集锦
2019/08/15 职场文书
教你如何用python开发一款数字推盘小游戏
2021/04/14 Python
Java使用httpRequest+Jsoup爬取红蓝球号码
2021/07/02 Java/Android
ajax请求前端跨域问题原因及解决方案
2021/10/16 Javascript
手把手带你彻底卸载MySQL数据库
2022/06/14 MySQL