把一个字符串中的字符重新排列生成新的字符串,返回新生成的字符串里没有连续重复字符的字符串个数.连续重复只以单个字符为准

例如, aab 应该返回 2 因为它总共有6中排列 (aab, aab, aba, aba, baa, baa), 但是只有两个 (aba and aba)没有连续重复的字符 (在本例中是 a).

SRE实战 互联网时代守护先锋,助力企业售后服务体系运筹帷幄!一键直达领取阿里云限量特价优惠。

当你遇到困难的时候,记得查看错误提示、阅读文档、搜索、提问。

这是一些对你有帮助的资源:

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');

 

扫码关注我们
微信号:SRE实战
拒绝背锅 运筹帷幄