1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57
|
#include<cstring> #include<string> #include<vector> #include<map> #include<iostream> #include<algorithm> using namespace std; vector<int>a[100]; map<string,int>b;
int (){ int T; scanf("%d",&T); while(T--){ int n,cnt=0; scanf("%d",&n); getchar(); for(int i=0;i<n;i++) a[i].clear(); b.clear(); while(n--){ char c; string line,snum,opp; while(scanf("%c",&c)&&c!='='&&c!='.'&&c!='[') snum.insert(snum.end(),1,c); if(c=='='){ if(!b.count(snum))b[snum]=cnt++; else a[b[snum]].clear(); getline(cin,line); } else if(c=='.'){ while(scanf("%c",&c)&&c!='(') opp.insert(opp.end(),1,c); if(opp[0]=='a'){ int x; scanf("%d",&x); a[b[snum]].push_back(x); } else { sort(a[b[snum]].begin(),a[b[snum]].end()); } getline(cin,line); } else { int x; scanf("%d",&x); if(x<a[b[snum]].size())printf("%dn",a[b[snum]][x]); else printf("ERRORn"); getline(cin,line); } } } return 0; }
|
近期评论