(暴力枚举 水题 长度为3的不同回文子序列)leetcode 1930

关键就是去重,暴力没啥好说明的

cpp 复制代码
class Solution {
public:
  
    int countPalindromicSubsequence(string s) {
        int ans = 0;
        int n = s.size();
        for (char i = 'a';i <= 'z';i++)//穷尽所有字母
        {
            int l= 0;
            int r = n - 1;
            while (l < n && s[l] != i)//找到左边第一个等于s[i]的下标
            {
                l++;
            }
            while (r > 0 && s[r] != i)//找到右边边第一个等于s[i]的下标
            {
                r--;
            }
            if (l >= r)//没找到跳过
            {
                continue;
            }
            //计算回文范围内不重复的字母数量 因为 在"bbcbaba"中,当i枚举到b则l=0,r=5,bbb与bbb算同一个子序列所以,在l和r去重后统计其中的字母数量
            //这里直接把l和r期间的值放入unordered_set在返回长度即可
            unordered_set<int>setf;
            for (int k = l + 1;k < r;k++)
                setf.insert(s[k]);
            ans += setf.size();




        }
        return ans;
    }
};
相关推荐
sqyno1sky3 小时前
C++中的契约编程
开发语言·c++·算法
优化控制仿真模型3 小时前
2026年最新驾考科目一考试题库2309道全。电子版pdf
经验分享·算法·pdf
qq_334903153 小时前
嵌入式C++驱动开发
开发语言·c++·算法
阿贵---3 小时前
C++代码规范化工具
开发语言·c++·算法
暮冬-  Gentle°4 小时前
自定义内存检测工具
开发语言·c++·算法
ccLianLian4 小时前
数论·欧拉函数
数据结构·算法
2501_945424804 小时前
C++编译期矩阵运算
开发语言·c++·算法
2301_815482934 小时前
C++中的类型标签分发
开发语言·c++·算法
xushichao19894 小时前
代码生成优化技术
开发语言·c++·算法
li星野4 小时前
RTOS面试完整模拟题(嵌入式系统方向)
arm开发·面试·职场和发展