当前位置: 首页 > news >正文

力扣9.24

2207. 字符串中最多数目的子序列

给你一个下标从 0 开始的字符串 text 和另一个下标从 0 开始且长度为 2 的字符串 pattern ,两者都只包含小写英文字母。

你可以在 text 中任意位置插入 一个 字符,这个插入的字符必须是 pattern[0] 或者 pattern[1] 。注意,这个字符可以插入在 text 开头或者结尾的位置。

请你返回插入一个字符后,text 中最多包含多少个等于 pattern 的 子序列 。

子序列 指的是将一个字符串删除若干个字符后(也可以不删除),剩余字符保持原本顺序得到的字符串。

数据范围

  • 1 <= text.length <= 105
  • pattern.length == 2
  • textpattern 都只包含小写英文字母。

分析

贪心,可以发现,若pattern[0]越往右放,它所贡献的子序列个数越小(只需要数后面有多少个pattern[1],因此pattern[0]最优的位置是放在开头,同理pattern[1]最优的位置是放在尾部,考虑这两种情况,求一下有多少子序列,然后取max

代码

typedef long long LL;
class Solution {
public:const static int N = 1e5 + 5;long long maximumSubsequenceCount(string text, string pattern) {int n = text.size();LL res1 = 0, res2 = 0;LL cnt1 = 1, cnt2 = 1;for(int i = 0; i < n; i ++ ) {if(text[i] == pattern[0] || text[i] == pattern[1]) {if(text[i] == pattern[1]) {res1 += cnt1;}if(text[i] == pattern[0]) cnt1 ++ ;}if(text[n - i - 1] == pattern[0] || text[n - i - 1] == pattern[1]) {if(text[n - i - 1] == pattern[0]) {res2 += cnt2;} if(text[n - i - 1] == pattern[1]) cnt2 ++ ;}}return max(res1, res2);}
};

http://www.lryc.cn/news/447681.html

相关文章:

  • NRF21540—低功耗蓝牙,蓝牙mesh、Thread和Zigbee和2.4 GHz私有协议范围扩展射频前端模块
  • 2024最新Linux Socket编程
  • Linux下的驱动开发二
  • 【JAVA报错已解决】 Java.lang.ArrayIndexOutOfBoundsException
  • 2024 CSP 游记
  • 双十一有什么推荐好物?,这些你不能错过的宝藏好物推荐
  • NSSCTF [HUBUCTF 2022 新生赛]simple_RE(变种base64编码)
  • clickhouse使用extract提取分号之前,之后,中间的内容
  • Unity3D Compute Shader同步详解
  • 3D模型在UI设计中应用越来越多,给UI带来了什么?
  • 前端框架的选择与考量:一场技术的盛宴
  • 第五部分:7---信号的捕捉
  • HarmonyOS鸿蒙开发实战( Beta5.0)页面加载效果实现详解实践案例
  • 计算机网络中的VLAN详解
  • Nacos学习
  • 后台数据管理系统 - 项目架构设计-Vue3+axios+Element-plus(0926)
  • 验收测试:从需求到交付的全程把控!
  • 第十七节 鼠标的操作与相应
  • 深圳·2025胶粘剂展会 BOND第六届胶展
  • 什么是网络安全自动化以及优势与挑战
  • java中的ArrayList和LinkedList的底层剖析
  • 占领矩阵-第15届蓝桥省赛Scratch中级组真题第5题
  • [论文笔记] Chain-of-Thought Reasoning without Prompting
  • C++八股进阶
  • 渗透测试--文件上传常用绕过方式
  • 音视频生态下Unity3D和虚幻引擎(Unreal Engine)的区别
  • 搭建基于H.265编码的RTSP推流云服务器
  • C++20 std::format
  • Python基础知识 (九)os模块、异常、异常的传递性
  • 鸿蒙手势交互(三:组合手势)