看到其他方法都偏复杂,来个简化版
#include<stdio.h>
struct stu{
int a;
char b[10];
};//定义结构体,注意此处名字长度的范围,定义大一些,pta很喜欢卡数据范围
int main()
{
int n;
scanf("%d",&n);//输入全班人数
struct stu p[51];//注意结构体数组大小要求
for(int i = 0;i<n;i++)
scanf("%d %s",&p[i].a,p[i].b);//输入每一个同学的性别和名字
for(int i = 0;i<n/2;i++){//我认为外层循环只能循环到前一半的同学,如果循环到后一半同学,数据肯定不符合题目要求,故i<n/2,你品你细品
for(int j = n-1;j>=n/2;j--){//内层就从最后一个同学到第n/2个同学
if(p[i].a!=p[j].a&&p[j].a!=-1){//如果两者为异性且成绩低的同学没有被查找过
printf("%s %s\n",p[i].b,p[j].b);
p[j].a=-1;//成绩低的同学性别被重命名为沃尔玛塑料袋后就不会参与下一次if判断
break;
}
}
}
return 0;
}
别让我发现电子235的来看这篇博客(狗头)