T1 题意:给你一个串,求所有子序列个数,满足没有相同字符。1e5,2s。
解:考虑一个合法的子序列。其中每个字母的出现位置都有(出现次数)种选择。还可以不选,要 + 1。
然后乘起来就做完了。如果变成子串的话更简单,每个位置为开头的长度不会超过26,直接暴力。本质不同子串就开个hash池判重。
本质不同子序列......不会。
1 #include <bits/stdc++.h> 2 3 const int N = 100010, MO = 1e9 + 7; 4 5 char str[N]; 6 int bin[26]; 7 8 int main() { 9 int n; 10 scanf("%d", &n); 11 scanf("%s", str); 12 for(int i = 0; i < n; i++) { 13 bin[str[i] - 'a']++; 14 } 15 int ans = 1; 16 for(int i = 0; i < 26; i++) { 17 ans = 1ll * ans * (bin[i] + 1) % MO; 18 } 19 printf("%d", (ans + MO - 1) % MO); 20 21 return 0; 22 }