FBI please teach meee. i will give you a gift then.
# | User | Rating |
---|---|---|
1 | tourist | 3985 |
2 | jiangly | 3814 |
3 | jqdai0815 | 3682 |
4 | Benq | 3529 |
5 | orzdevinwang | 3526 |
6 | ksun48 | 3517 |
7 | Radewoosh | 3410 |
8 | hos.lyric | 3399 |
9 | ecnerwala | 3392 |
9 | Um_nik | 3392 |
# | User | Contrib. |
---|---|---|
1 | cry | 169 |
2 | maomao90 | 162 |
2 | Um_nik | 162 |
4 | atcoder_official | 161 |
5 | djm03178 | 158 |
6 | -is-this-fft- | 157 |
7 | adamant | 155 |
8 | awoo | 154 |
8 | Dominater069 | 154 |
10 | luogu_official | 150 |
FBI please teach meee. i will give you a gift then.
FBI is such a prooo. But im better :()()()()()() i am his COACH
i don't know. Please help me what they do FBI
#include <bits/stdc++.h>
using namespace std;
int main()
{
string s;cin>>s;
int n=s.size();
vector<vector<int>>dp(n,vector<int>(18));
for(int i=0;i<n;i++)
{
dp[i][0]=(1<<(s[i]-'a'));
}
for(int k=1;k<18;k++)
{
for(int i=0;i+(1<<k)-1<n;i++)
{
dp[i][k]=(dp[i][k-1]|dp[i+(1<<(k-1))][k-1]);
}
}
auto get=[&](int l,int r)
{
int k=31-__builtin_clz(r-l+1);
int x=(dp[l][k]|dp[r-(1<<k)+1][k]);
return __builtin_popcount(x);
};
int q;cin>>q;
while(q--)
{
int l,r;cin>>l>>r;
cout<<get(l-1,r-1)<<endl;
}
}
Name |
---|