-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathnested_lists.py
More file actions
93 lines (67 loc) · 2.37 KB
/
nested_lists.py
File metadata and controls
93 lines (67 loc) · 2.37 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
"""
Nested Lists
Given the names and grades for each student in a Physics class of N students,
store them in a nested list and print the name(s) of any student(s)
having the second lowest grade.
Note: If there are multiple students with the same grade,
order their names alphabetically and print each name on a new line.
Input Format:
The first line contains an integer, N, the number of students.
The 2N subsequent lines describe each student over 2 lines;
the first line contains a student's name,
and the second line contains their grade.
Constraints:
2 <= N <= 5
There will always be one or more students having the second lowest grade.
Output Format:
Print the name(s) of any student(s) having the second lowest grade in Physics;
if there are multiple students, order their names alphabetically
and print each one on a new line.
Sample Input:
5
Harry
37.21
Berry
37.21
Tina
37.2
Akriti
41
Harsh
39
Sample Output:
Berry
Harry
Explanation:
There are 5 students in this class whose names and grades
are assembled to build the following list:
python students = [['Harry', 37.21], ['Berry', 37.21],
['Tina', 37.2], ['Akriti', 41], ['Harsh', 39]]
The lowest grade of 37.2 belongs to Tina.
The second lowest grade of 37.21 belongs to both Harry and Berry,
so we order their names alphabetically and print each name on a new line.
@author: Luísa Maria
"""
def sort_byName(alist):
return alist[0]
def sort_byGrades(alist):
return alist[1]
def nested_lists():
number_entries = int(input("Number of students: "))
students = []
if(number_entries < 2 or number_entries > 5):
return "Error!"
while(number_entries > 0):
name = input("Name: ")
grade = float(input("Grade: "))
new_student = [name, grade]
students.append(new_student)
number_entries = number_entries - 1
#sort by students's names
students.sort(key = sort_byName, reverse = False)
#sort by students's grades
students.sort(key = sort_byGrades, reverse = False)
student_with_second_lowest_grade = students[1]
for student in students:
if(student[1] == student_with_second_lowest_grade[1]):
print(student[0])