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 相关文章推荐
Window.Open如何在同一个标签页打开
Jun 20 Javascript
JavaScript设置获取和设置属性的方法
Mar 04 Javascript
jquery+easeing实现仿flash的载入动画
Mar 10 Javascript
JavaScript数据类型学习笔记
Jan 25 Javascript
jQuery简单自定义图片轮播插件及用法示例
Nov 21 Javascript
Javascript 一些需要注意的细节(必看篇)
Jul 08 Javascript
angular第三方包开发整理(小结)
Apr 19 Javascript
vue弹窗插件实战代码
Sep 08 Javascript
小程序:授权、登录、session_key、unionId的详解
May 15 Javascript
Vue+Element实现动态生成新表单并添加验证功能
May 23 Javascript
原生JS实现微信通讯录
Jun 18 Javascript
解决vue侦听器watch,调用this时出现undefined的问题
Oct 30 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+dbfile开发小型留言本
2006/10/09 PHP
php将图片保存为不同尺寸图片的图片类实例
2015/03/30 PHP
php把字符串指定字符分割成数组的方法
2018/03/12 PHP
简单的JS多重继承示例
2008/03/13 Javascript
Js 中debug方式
2010/02/07 Javascript
JQuery跳出each循环的方法
2015/04/16 Javascript
jQuery弹出层插件Lightbox_me使用指南
2015/04/21 Javascript
JavaScript实现获得所有兄弟节点的方法
2015/07/23 Javascript
轻松学习jQuery插件EasyUI EasyUI实现拖动基本操作
2015/11/30 Javascript
快速移动鼠标触发问题及解决方法(ECharts外部调用保存为图片操作及工作流接线mouseenter和mouseleave)
2016/08/29 Javascript
jquery实现文字单行横移或翻转(上下、左右跳转)
2017/01/08 Javascript
Angular.js指令学习中一些重要属性的用法教程
2017/05/24 Javascript
JS实现下拉菜单列表与登录注册弹窗效果
2017/08/10 Javascript
vue2.0+vue-dplayer实现hls播放的示例
2018/03/02 Javascript
解决前后端分离 vue+springboot 跨域 session+cookie失效问题
2019/05/13 Javascript
原生JS使用Canvas实现拖拽式绘图功能
2019/06/05 Javascript
vue实现动态表格提交参数动态生成控件的操作
2020/11/09 Javascript
[01:14]3.19DOTA2发布会 三代刀塔人第二代
2014/03/25 DOTA
Python+Selenium自动化实现分页(pagination)处理
2017/03/31 Python
python数据结构学习之实现线性表的顺序
2018/09/28 Python
解决python打不开文件(文件不存在)的问题
2019/02/18 Python
Django框架自定义模型管理器与元选项用法分析
2019/07/22 Python
Python实现直播推流效果
2019/11/26 Python
Python魔法方法 容器部方法详解
2020/01/02 Python
Python使用pyyaml模块处理yaml数据
2020/04/14 Python
keras的load_model实现加载含有参数的自定义模型
2020/06/22 Python
Python描述数据结构学习之哈夫曼树篇
2020/09/07 Python
Python plt 利用subplot 实现在一张画布同时画多张图
2021/02/26 Python
沙特阿拉伯网上购物:Sayidaty Mall
2018/05/06 全球购物
纽约市的奢华内衣目的地:Anya Lust
2019/08/02 全球购物
试述DBMS的主要功能
2016/11/13 面试题
广州品高软件.net笔面试题目
2012/04/18 面试题
本科生自荐信
2014/06/18 职场文书
心得体会的写法
2014/09/05 职场文书
教师年度考核个人总结
2015/02/12 职场文书
GTX1660显卡搭配显示器推荐
2022/04/19 数码科技