#include <cstdio>
#include <vector>
#include <cstring>
#include <algorithm>
using namespace std;
const int maxn=40010;
const int maxc=2510;
vector<int> course[maxc];//课程最大数不该超过2500
char name[maxc][5];//name为二维数组
bool cmp(int a,int b){
return strcmp(name[a],name[b])<0;//按字典顺序排序
}
int main(){
int n,k,c,courseID;
scanf("%d%d",&n,&k);
for(int i=0;i<n;i++){
scanf("%s %d",name[i],&c);
for(int j=0;j<c;j++){
scanf("%d",&courseID);
course[courseID].push_back(i);//将第i个学生对应到第courseID号课上
}
}
for(int i=1;i<=k;i++){
printf("%d %d\n",i,course[i].size());//course[i].size()第i门课选的总人数
sort(course[i].begin(),course[i].end(),cmp);
for(int j=0;j<course[i].size();j++){
printf("%s\n",name[course[i][j]]);
}
}
return 0;
}
A1047
最新推荐文章于 2020-08-23 12:37:47 发布