No repeats please 全排列
2019-04-12 09:28:51来源:博客园 阅读 ()
把一个字符串中的字符重新排列生成新的字符串,返回新生成的字符串里没有连续重复字符的字符串个数.连续重复只以单个字符为准
例如, aab
应该返回 2 因为它总共有6中排列 (aab
, aab
, aba
, aba
, baa
, baa
), 但是只有两个 (aba
and aba
)没有连续重复的字符 (在本例中是 a
).
当你遇到困难的时候,记得查看错误提示、阅读文档、搜索、提问。
这是一些对你有帮助的资源:
- Permutations
- RegExp
permAlone("aab")
应该返回一个数字.permAlone("aab")
应该返回 2.permAlone("aaa")
应该返回 0.permAlone("aabb")
应该返回 8.permAlone("abcdefa")
应该返回 3600.permAlone("abfdefa")
应该返回 2640.permAlone("zzzzzzzz")
应该返回 0.function permAlone(str) { //采用递归算法需要的前提条件是,当且仅当一个存在预期的收敛时,才可采用递归算法,否则,就不能使用递归算法。遇到满足终止条件的情况时逐层返回来结束。 //迭代 使用计数器结束循环。 var arr = str.split(""); var newArr = []; var ne = []; var ex = /(.)\1+/g; function per(arr, n, aL){ if(n == aL-1){ newArr.push(arr.join("")); }else{ for(var i = n; i < aL; i++){ var tmp = arr[i]; arr[i] = arr[n]; arr[n]= tmp; per(arr, n+1, aL); tmp = arr[i]; arr[i] = arr[n]; arr[n]= tmp; } } return newArr; } var p = per(arr, 0, arr.length); for(var j = 0; j <p.length; j++){ if(!p[j].match(ex)){ ne.push(p[j]); } } // return ne.length; } permAlone('abcd');
原文链接:https://www.cnblogs.com/leina-2017-09-01/p/10696333.html
如有疑问请与原作者联系
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
- JS实现数组按升序及降序排列的方法 2019-12-15
- 用js写三个数,让三个数从小到大排列 2018-06-24
- 前端学算法之排序算法 2018-06-24
- Please set registry key HKLM\Microsoft\.NET Framework\In 2018-06-23
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash