1930: 长度为3的不同回文子序列
思路:
-
对每个字符
a,找到它在字符串中第一次出现的位置 和最后一次出现的位置; -
在这两个位置之间的不同字符个数 就是能组成
a x a的个数(x可以包含它本身); -
把所有字符的这个数量加起来就是答案。
vector<int> first(26,-1);
一次性开出 26 个 int 单元,全部初始化为 -1。
int c = s[i] - 'a';

std::unordered_set 的 insert 是"若已存在则什么都不做 "的幂等操作:
-
元素不存在 → 插入,返回
pair<iterator, true> -
元素已存在 → 直接忽略,返回
pair<iterator, false>class Solution {
public:
int countPalindromicSubsequence(string s) {
int n=s.size();
int ans=0;
vector<int> first(26,-1); //对应英文小写字母 'a' 到 'z',全部初始化为 -1
vector<int> last(26,-1);// 记录每个字符的第一次和最后一次出现位置 for(int i=0;i<n;i++){ int c = s[i] - 'a'; if (first[c] == -1) first[c] = i; last[c] = i; } // 对每个字符 a,统计 first[a] 和 last[a] 之间的不同字符数 for(int j=0;j<26;j++){ if(first[j]==-1 || last[j]==-1 || first[j]+1>=last[j]) continue; unordered_set<char> cnt; for(int m=first[j]+1;m<last[j];m++){ cnt.insert(s[m]); } ans+=cnt.size(); } return ans; }};