【正则表达式的妙用】

题目:

给定一个字符串,折叠操作的定义为:

1、对其中连续的字符可以进行删除字符操作,但要保证至少保留其中1个字符;

2、一次可以对多个不同的连续字符进行删除字符操作

如给定字符串 "abbbcccbbbeeef", 通过折叠操作可以得到"abcccbbbeeef", "abcccbeeef", "abcbef"等,但是不能得到 "acccbbbeeef", "abbeeef"

给定一个字符串和一个子序列数组,返回子序列数组中符合条件的子序列个数

思路:

为字符串构建正则表达式,比如 "abbbcccbbbeeef" => "ab{1,3}c{1,3}b{1,3}e{1,3}f"

js 复制代码
//根据字符串构造正则 
const getCount = (str, arr) => {
  // 获得正则模板
  str += "$"; // 哨兵位,这样不用为最后一个元素做特殊处理
  let count = 0;
  let reg = "";
  for (let i = 1; i < str.length; i++) {
    if (str[i] === str[i - 1]) {
      count++;
    } else {
      if (count === 0) {
        reg += str[i - 1];
        continue;
      }
      reg += str[i - 1] + `{1,${count + 1}}`;
      count = 0;
    }
  }
  return arr.filter((item) => new RegExp(reg).test(item)).length;
};

console.log(
  getCount("abbbcccbbbeeeff", [
    "abcccbbbeeef",
    "abcccbeeef",
    "abcbef",
    "acccbbbeeef",
    "abbeeef",
  ])
);

console.log(getCount("bbbeeef", ["bf", "bef", "ef", "beeeef"]));
相关推荐
hdsoft_huge1 小时前
Java & Spring Boot常见异常全解析:原因、危害、处理与防范
java·开发语言·spring boot
风中的微尘1 小时前
39.网络流入门
开发语言·网络·c++·算法
前端君1 小时前
实现最大异步并发执行队列
javascript
未来之窗软件服务2 小时前
幽冥大陆(二)RDIFSDK 接口文档:布草洗涤厂高效运营的技术桥梁C#—东方仙盟
开发语言·c#·rdif·仙盟创梦ide·东方仙盟
小冯记录编程2 小时前
C++指针陷阱:高效背后的致命危险
开发语言·c++·visual studio
1uther2 小时前
Unity核心概念⑨:Screen
开发语言·游戏·unity·c#·游戏引擎
知识分享小能手2 小时前
React学习教程,从入门到精通,React 组件核心语法知识点详解(类组件体系)(19)
前端·javascript·vue.js·学习·react.js·react·anti-design-vue
C_Liu_3 小时前
C++:类和对象(下)
开发语言·c++
coderxiaohan3 小时前
【C++】类和对象1
java·开发语言·c++
阿幸软件杂货间3 小时前
Office转PDF转换器v1.0.py
开发语言·pdf·c#