第6章-2.一帮一 (15分)

“一帮一学习小组”是中小学中常见的学习组织方式,老师把学习成绩靠前的学生跟学习成绩靠后的学生排在一组。本题就请你编写程序帮助老师自动完成这个分配工作,即在得到全班学生的排名后,在当前尚未分组的学生中,将名次最靠前的学生与名次最靠后的异性学生分为一组。

输入格式:

输入第一行给出正偶数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
 1 # 一帮一
 2 # Author: cnRick
 3 # Time  : 2020-4-13
 4 n = int(input())
 5 stus= dict()
 6 boys,girls = list(),list()
 7 boysPoint,girlsPoint = 0,0
 8 for i in range(n): #构建学生字典(姓名:性别(用0和1表示)),并且把男生和女生分两组
 9     thisLine = input().split()
10     stus[thisLine[1]] = thisLine[0]
11     if thisLine[0] == "0":
12         girls.append(thisLine[1])
13     elif thisLine[0] == "1":
14         boys.append(thisLine[1])
15 
16 girls.reverse()
17 boys.reverse()
18 
19 breakCnt = 0
20 for name,gender in stus.items():
21     if gender == "0":
22         print("{} {}".format(name,boys[boysPoint]))
23         boysPoint += 1
24         breakCnt += 1
25     elif gender == "1":
26         print("{} {}".format(name,girls[girlsPoint]))
27         girlsPoint += 1
28         breakCnt += 1
29     if breakCnt == n//2:
30         break
31 
32     

 

 
posted @ 2020-04-13 18:48  cnRicky  阅读(661)  评论(0编辑  收藏  举报