前言
一道15分的题目,难度还可以,题目的内容都在幻想中,看题
L1-030 一帮一
“一帮一学习小组”是中小学中常见的学习组织方式,老师把学习成绩靠前的学生跟学习成绩靠后的学生排在一组。本题就请你编写程序帮助老师自动完成这个分配工作,即在得到全班学生的排名后,在当前尚未分组的学生中,将名次最靠前的学生与名次最靠后的异性学生分为一组。
输入格式:
输入第一行给出正偶数N
(≤50),即全班学生的人数。此后N行,按照名次从高到低的顺序给出每个学生的性别(0代表女生,1代表男生)和姓名(不超过8个英文字母的非空字符串),其间以1个空格分隔。这里保证本班男女比例是1:1,并且没有并列名次。
输出格式:
每行输出一组两个学生的姓名,其间以1个空格分隔。名次高的学生在前,名次低的学生在后。小组的输出顺序按照前面学生的名次从高到低排列。
输入样例:
8
0 Amy
1 Tom
1 Bill
0 Cindy
0 Maya
1 John
1 Jack
0 Linda
输出样例:
Amy Jack
Tom Linda
Bill Maya
Cindy John
OK,以上是全部的题目,题目的内容就是按排名给出班级所有人的性别及姓名,一对一帮助,一男一女,最高排名和最低排名向中间排名凑对,然后输出每一对的姓名,排名高的在前,低的在后。
思路
这道题的思路是什么呢,先定义一个结构体,去存储这个班级人的姓名及性别,按排名存储,然后,判断从前从后同时输出,并且判断是否为异性。
(讲话了,我高中在理科班,30多个人,就三个女的还是因为看我班没女的凑来的)
代码
#include <stdio.h>
struct Student{//定义结构体存储性别姓名
int xing;
char name[9];
};
struct Student s[50] = {0};//数组存储所有人的信息
int main()
{
int n;
scanf("%d",&n);//输入班级人数
int i,j;
for(i = 0;i < n;i++)//输入每个学生的信息
scanf("%d %s",&s[i].xing,&s[i].name);
for(i = 0;i < n;i++)//从前往后
for(j = n-1;j > i;j--)//从后往前
if(s[i].xing != s[j].xing&&s[j].xing != 2)//判断是否为异性,并且判断这个人是否输出过
{
printf("%s %s\n",s[i].name,s[j].name);s[j].xing = 2;break;
}
}
以上所有代码均为自己编写,本人水平有限,如果有哪里出错或者有更好的解法可以与我私信或在评论区里进行讨论
上一题:团体程序设计天梯赛-练习集——L1-029 是不是太胖了
下一题:团体程序设计天梯赛-练习集——L1-031 到底是不是太胖了