给定一个字符串 s,计算具有相同数量0和1的非空(连续)子字符串的数量,并且这些子字符串中的所有0和所有1都是组合在一起的。

重复出现的子串要计算它们出现的次数。

示例:

输入: "00110011"
输出: 6
解释: 有6个子串具有相同数量的连续1和0:“0011”,“01”,“1100”,“10”,“0011” 和 “01”。

请注意,一些重复出现的子串要计算它们出现的次数。

另外,“00110011”不是有效的子串,因为所有的0(和1)没有组合在一起。
const str = '00110011'
// 给定任意子输入都返回第一个符合条件的子串
function cal(str){
  let r = []
  let match = (str) => {
    let j = str.match(/^(0+|1+)/)[0]
    let o = (j[0] ^ 1).toString().repeat(j.length)
    let reg = new RegExp(`^(${j}${o})`)
    if (reg.test(str)) {
      return RegExp.$1
    } else {
      return ''
    }
  }
  // 通过for循环控制程序运行的流程
  for (let i = 0, len = str.length - 1; i < len; i++) {
    let sub = match(str.slice(i))
    if (sub) {
      r.push(sub)
    }
  }
  return r
}
console.log(cal(str)) //[ '0011', '01', '1100', '10', '0011', '01' ]

相关文章:

  • 2021-06-05
  • 2022-03-02
  • 2022-01-09
  • 2022-01-19
  • 2021-11-10
  • 2022-12-23
  • 2021-11-14
猜你喜欢
  • 2021-04-29
  • 2022-01-06
  • 2022-12-23
  • 2021-10-21
  • 2021-08-31
  • 2022-01-04
  • 2022-12-23
相关资源
相似解决方案