“一帮一学习小组”是中小学中常见的学习组织方式,老师把学习成绩靠前的学生跟学习成绩靠后的学生排在一组。本题就请你编写程序帮助老师自动完成这个分配工作,即在得到全班学生的排名后,在当前尚未分组的学生中,将名次最靠前的学生与名次最靠后的异性学生分为一组。
输入格式:
输入第一行给出正偶数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
思路:
建立两个列表,girl、boy分别表示女生和男生,列表中的每一项也是一个列表,存储该学生的姓名的排名。随后将其中一个列表倒置,用zip将两个列表每一项打包。这样就可以将男生女生都分组好,但是这样的分组并没有进行排序(包括组内、组与组之间)。
因为要求每一组里面排名前的先打印,组的打印也按照每组第一个的排名。所以先进行组内的排序,利用sorted()函数,将lst里的每一项(一个元组,元组里面有两个列表,分别表示一男一女,我们要排序的便是这一男一女两个列表的先后)先排序好,然后再整个lst列表,按照每组第一个学生的排名排序。
**要注意sorted()函数并不会在传入的列表上修改,而是返回一个新的列表,这和list自带的sort函数不一样
有关python的sorted函数的使用可以参考菜鸟教程:Python sorted()
源码:
n=int(input())
girl=[]
boy=[]
for i in range(0,n):
sex,name=input().split()
if sex=='0':
girl.append([name,i])
else:
boy.append([name,i])
boy.reverse()
lst=list(zip(girl,boy))
for i in range(0,len(lst)):
lst[i]=sorted(lst[i],key=lambda s:s[1])
lst=sorted(lst,key=lambda s:s[0][1])
for people in lst:
print("{:} {:}".format(people[0][0],people[1][0]))