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 自动分号插入(JavaScript synat:auto semicolon insertion)
Nov 04 Javascript
使用js显示当前时间示例
Mar 02 Javascript
Javascript中的高阶函数介绍
Mar 15 Javascript
AngularJS中如何使用$parse或$eval在运行时对Scope变量赋值
Jan 25 Javascript
浅谈JavaScript对象与继承
Jul 10 Javascript
React实现双向绑定示例代码
Sep 19 Javascript
Reactjs实现通用分页组件的实例代码
Jan 19 Javascript
Vue-Router的使用方法
Sep 05 Javascript
vue 2.8.2版本配置刚进入时候的默认页面方法
Sep 21 Javascript
微信小程序开发之左右分栏效果的实例代码
May 20 Javascript
js键盘事件实现人物的行走
Jan 17 Javascript
react中hook介绍以及使用教程
Dec 11 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
php Xdebug 调试扩展的安装与使用.
2010/03/13 PHP
让codeigniter与swfupload整合的最佳解决方案
2014/06/12 PHP
PHP实现根据设备类型自动跳转相应页面的方法
2014/07/24 PHP
php事务回滚简单实现方法示例
2017/03/28 PHP
PHP实现根据数组的值进行分组的方法
2017/04/20 PHP
利用laravel搭建一个迷你博客实战教程
2017/08/13 PHP
PHP fprintf()函数用法讲解
2019/02/16 PHP
Nginx+php配置文件及原理解析
2020/12/09 PHP
window.location和document.location的区别分析
2008/12/23 Javascript
javascript 快速排序函数代码
2012/05/30 Javascript
JavaScript实现页面5秒后自动跳转的方法
2015/04/16 Javascript
JavaScript使用forEach()与jQuery使用each遍历数组时return false 的区别
2016/08/26 Javascript
基于bootstrap-datetimepicker.js不支持IE8的快速解决方法
2016/11/07 Javascript
详解Angular 4.x Injector
2017/05/04 Javascript
AngularJS中使用ngModal模态框实例
2017/05/27 Javascript
浅谈使用nodejs搭建web服务器的过程
2020/07/20 NodeJs
vue 实现tab切换保持数据状态
2020/07/21 Javascript
浅谈JavaScript节流和防抖函数
2020/08/25 Javascript
Python正则表达式匹配HTML页面编码
2015/04/08 Python
python去除所有html标签的方法
2015/05/05 Python
Python实现将HTML转换成doc格式文件的方法示例
2017/11/20 Python
Python3 加密(hashlib和hmac)模块的实现
2017/11/23 Python
Python代码块批量添加Tab缩进的方法
2018/06/25 Python
Python学习笔记之Django创建第一个数据库模型的方法
2019/08/07 Python
使用pyecharts生成Echarts网页的实例
2019/08/12 Python
python GUI库图形界面开发之PyQt5打印控件QPrinter详细使用方法与实例
2020/02/28 Python
荷兰网上买鞋:MooieSchoenen.nl
2017/09/12 全球购物
Ibatis中如何提高SQL Map的性能
2013/05/11 面试题
EJB实例的生命周期
2016/10/28 面试题
物流创业计划书
2014/02/01 职场文书
企业宣传策划方案
2014/05/29 职场文书
计划生育证明格式范本
2014/09/12 职场文书
2015年超市工作总结
2015/04/09 职场文书
2015年幼儿园班主任工作总结
2015/05/12 职场文书
Spring Cloud Gateway去掉url前缀
2021/07/15 Java/Android
Mysql数据库手动及定时备份步骤
2021/11/07 MySQL