3
CS003 60
CS001 37
CS004 37
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
typedef struct student{
char name[21];
int ss;
int num[11]; //二级里面可以动态申请不
int sum;
}student;
void swap(student *x,student *y){
student *t;
t=(student *)malloc(sizeof(student));
*t=*x;
*x=*y;
*y=*t;
}
int main(){
int i,j,n,m,g,*a;
student *stu,t;
scanf("%d %d %d",&n,&m,&g);
a=(int *)malloc(sizeof(int)*(m+1));
stu=(student *)malloc(sizeof(student)*n);
for(i=1;i<=m;i++)
scanf("%d",&a[i]);
getchar();
for(i=0;i<n;i++){
scanf("%s %d",stu[i].name,&stu[i].ss);
stu[i].sum=0;
for(j=0;j<stu[i].ss;j++){
scanf("%d",&stu[i].num[j]);
stu[i].sum+=a[stu[i].num[j]];
}
}
for(i=1;i<n;i++){
for(j=0;j<n-i;j++){
if(stu[j].sum<stu[j+1].sum)
swap(&stu[j],&stu[j+1]);
else if(stu[j].sum==stu[j+1].sum){
if(strcmp(stu[j].name,stu[j+1].name)>0)
swap(&stu[j],&stu[j+1]);
}
}
}
int cnt=0;
for(i=0;i<n;i++){
if(stu[i].sum>=g)
cnt++;
}
printf("%d\n",cnt);
for(i=0;i<n;i++)
if(stu[i].sum>=g)
printf("%s %d\n",stu[i].name,stu[i].sum);
return 0;
}