标签:int 题解 退选 char THUSC2016 num cmp 字典 size
一道字典树的例题吧
先说下思路前1,2两个条件都易满足,字典树插入修改即可,第三个条件可用动态数组来实现,存下它的size表示当前有几个节点经过(即人数),其下标表示第几次出现,里面存入操作次数(即时刻),然后字典树修改即可。
上代码
#include<bits/stdc++.h>
using namespace std;
const int N=300000;//开大点200000有一个点没过
struct node{
int ch[30],size;
vector<int> cmp;//动态数组
}trie[N];
int n,k,tot,a,b,c,ans;
char str[100];
struct tr{
void ins(char a[],int num){//插入
int len=strlen(a);
int p=0;
for(int i=0;i<len;++i){
int v=a[i]-'a';
if(!trie[p].ch[v]) trie[p].ch[v]=++tot;
p=trie[p].ch[v];
trie[p].size++;
if(trie[p].size>trie[p].cmp.size())trie[p].cmp.push_back(num);
}
}
void deal(char a[]){//删除
int p=0,len=strlen(a);
for(int i=0;i<len;++i){
int v=a[i]-'a';
p=trie[p].ch[v];
trie[p].size--;
}
}
int found(char s[],long long a,long long b,long long c){//找答案
int p=0,len=strlen(s);
long long tmp=(a*abs(ans)+b)%c;
for(int i=0;i<len;++i){
int v=s[i]-'a';
p=trie[p].ch[v];
if(trie[p].cmp.size()<=tmp) return -1;//没超过
}
return trie[p].cmp[tmp];
}
}tr;
int main(){
scanf("%d",&n);
for(int i=1;i<=n;++i){
scanf("%d",&k);
if(k==1){
scanf("%s",str);
tr.ins(str,i);
}
if(k==2){
scanf("%s",str);
tr.deal(str);
}
if(k==3){
scanf("%s",str);
scanf("%d %d %d",&a,&b,&c);
printf("%d\n",ans=tr.found(str,a,b,c));//记得修改答案
}
}
return 0;
}
标签:int,题解,退选,char,THUSC2016,num,cmp,字典,size 来源: https://www.cnblogs.com/donkey2603089141/p/11414545.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。