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高级程序设计阅读笔记(五) ECMAScript中的运算符(一)
Feb 27 Javascript
Javascript常用字符串判断函数代码分享
Dec 08 Javascript
常用原生JS兼容性写法汇总
Apr 27 Javascript
浅谈jquery.form.js的ajaxSubmit和ajaxForm的使用
Sep 09 Javascript
微信小程序  网络请求API详解
Oct 25 Javascript
JS实现复制功能
Mar 01 Javascript
js省市区级联查询(插件版&amp;无插件版)
Mar 21 Javascript
jQuery自定义元素右键点击事件(实现案例)
Apr 28 jQuery
微信小程序 自动登陆PHP源码实例(源码下载)
May 08 Javascript
使用vue-cli3 创建vue项目并配置VS Code 自动代码格式化 vue语法高亮问题
May 14 Javascript
微信公众号获取用户地理位置并列出附近的门店的示例代码
Jul 25 Javascript
uni-app微信小程序登录并使用vuex存储登录状态的思路详解
Nov 04 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与MySQL开发中页面乱码的产生与解决
2008/03/27 PHP
php实现的获取网站备案信息查询代码(360)
2013/09/23 PHP
使用php验证复选框有效性的示例
2013/11/13 PHP
PHP使用xmllint命令处理xml与html的方法
2014/12/15 PHP
php使用正则表达式进行字符串搜索的方法
2015/03/23 PHP
Laravel 5框架学习之模型、控制器、视图基础流程
2015/04/08 PHP
浅谈PHP中关于foreach使用引用变量的坑
2016/11/14 PHP
ff下JQuery无法监听input的keyup事件的解决方法
2013/12/12 Javascript
JS对象与json字符串格式转换实例
2014/10/28 Javascript
jquery实现标题字体变换的滑动门菜单效果
2015/09/07 Javascript
jQuery实现鼠标滑过链接控制图片的滑动展开与隐藏效果
2015/10/28 Javascript
简介EasyUI datagrid editor combogrid搜索框的实现
2016/04/01 Javascript
Function.prototype.apply()与Function.prototype.call()小结
2016/04/27 Javascript
JS组件Bootstrap Table布局详解
2016/05/27 Javascript
一种基于浏览器的自动小票机打印实现方案(js版)
2016/07/26 Javascript
详解Angular中$cacheFactory缓存的使用
2016/08/19 Javascript
JavaScript随机生成颜色的方法
2016/10/15 Javascript
JS正则表达式验证密码格式的集中情况总结
2017/02/23 Javascript
nuxt.js中间件实现拦截权限判断的方法
2018/11/21 Javascript
JavaScript一元正号运算符示例代码
2019/06/30 Javascript
Node绑定全局TraceID的实现方法
2019/11/14 Javascript
[02:45]DOTA2英雄基础教程 伐木机
2013/12/23 DOTA
在HTML5 Canvas中放入图片和保存为图片的方法
2014/05/03 HTML / CSS
html5利用canvas实现颜色容差抠图功能
2019/12/23 HTML / CSS
凯特方迪化妆品官网:Kat Von D Beauty
2016/11/15 全球购物
个人求职信范文分享
2014/01/31 职场文书
逃课上网检讨书
2014/02/20 职场文书
应届生求职自荐信范文
2014/04/07 职场文书
工作鉴定评语
2014/05/04 职场文书
幼儿园教师师德师风演讲稿:爱我所爱 无悔青春
2014/09/10 职场文书
党员“四风”问题批评与自我批评思想汇报
2014/10/06 职场文书
幼儿园教师师德承诺书
2015/04/28 职场文书
2016年毕业实习心得体会范文
2015/10/09 职场文书
交通事故协议书范本
2016/03/19 职场文书
CSS3 Tab动画实例之背景切换动态效果
2021/08/23 HTML / CSS
python神经网络学习 使用Keras进行简单分类
2022/05/04 Python