HackerRank Python: Nested Lists Solution

Table of Contents

Question

Given the names and grades for each student in a 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 second lowest grade, order their names alphabetically and print each name on a new line.

Example

records  = [[ “chi”, 20.0]], [“beta”, 50.0], [“alpha”, 50.0]

The ordered list of scores is [20.0, 50.0], so the second lowest score is  50.0 . There are two students with that score:  [“beta”, “alpha”]. 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

  • 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. 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 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.

Solution

				
					if __name__ == '__main__':
    li = []
    for _ in range(int(input())):
        name = input()
        score = float(input())
        li.append([name,score])
scr = [x[1] for x in li]
min_li = sorted(set(scr))
stud = sorted([y[0] for y in li if y[1]==min_li[1]])
[print(k) for k in stud]

				
			

This programme reads in a number of student names and grades, then stores them in a list of lists named “li” where each sublist has a name and a grade. After that, it makes a new list called “scr” that just contains the results from “li” and assigns it to the variable “scr.” Then, a new variable called “min_li” is created, which keeps a collection of scores arranged in ascending order. The names of the students whose scores match the second-lowest score from “min_li” are then added to the new variable “stud.” The names of the students who received the second-worst grade are printed after iterating through “stud” one more time.

If you find anything wrong in this Solution, feel free to reach us in the comment section.

Sharing Is Caring:

Leave a Comment