Skip to content

Instantly share code, notes, and snippets.

@elowy01
Created September 28, 2021 10:45
Show Gist options
  • Save elowy01/8b9e8f5ccc46b0ca0d79031310a35161 to your computer and use it in GitHub Desktop.
Save elowy01/8b9e8f5ccc46b0ca0d79031310a35161 to your computer and use it in GitHub Desktop.
"""
Given the names and grades for each student in a class of 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 second lowest grade, order their names alphabetically and print each name on a new line.
Example
The ordered list of scores is , so the second lowest score is . There are two students with that score: . Ordered alphabetically, the names are printed as:
alpha
beta
Input Format
The first line contains an integer, , the number of students.
The subsequent lines describe each student over lines.
- The first line contains a student's name.
- The second line contains their grade.
Constraints
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. If there are multiple students, order their names alphabetically and print each one on a new line.
Sample Input 0
5
Harry
37.21
Berry
37.21
Tina
37.2
Akriti
41
Harsh
39
Sample Output 0
Berry
Harry
Explanation 0
There are 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 belongs to Tina. The second lowest grade of belongs to both Harry and Berry, so we order their names alphabetically and print each name on a new line.
"""
if __name__ == '__main__':
sheet = []
for _ in range(int(input())):
name = input()
score = float(input())
sheet.append([name, score])
# flatten list
only_floats = list(set([item for sublist in sheet for item in sublist if not isinstance(item,str)]))
only_floats.sort()
second = only_floats[1]
names = []
for i in sheet:
if i[1] == second:
names.append(i[0])
names.sort()
for _ in names:
print(_)
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment