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
| #include <cstdio> #include <vector> #include <string> #include <map> #include <algorithm> #include <iostream> using namespace std; const int N=4e4+10; map<string,vector<int>> mmp; void insertmap(string s,int x){ if (mmp.count(s)!=0){ mmp[s].push_back(x); }else{ vector<int> v; v.push_back(x); mmp[s]=v; } }
int main(){ int n,m,c,st; string name; scanf("%d%d",&n,&m); for(int i=0;i<m;i++){ scanf("%d%d",&c,&st); for(int j=0;j<st;j++){ cin>>name; insertmap(name,c); } } string query; for(int i=0;i<n;i++){ cin>>query; int len=mmp[query].size(); printf("%s %d",query.c_str(),len); sort(mmp[query].begin(),mmp[query].end()); for(int j=0;j<len;j++){ printf(" %d",mmp[query][j]); } printf("\n"); }
return 0; }
|