Decorators 2 - Name Directory - Hacker Rank Solution
Let's use decorators to build a name directory! You are given some information about people. Each person has a first name, last name, age and sex. Print their names in a specific
format sorted by their age in ascending order i.e. the youngest person's name should be printed first. For two people of the same age, print them in the order of their input.For Henry Davids, the output should be:
Mr. Henry Davids
For Mary George, the output should be:
Ms. Mary George
Input Format
The first line contains the integer , the number of people.
lines follow each containing the space separated values of the first name, last name, age and sex, respectively.
lines follow each containing the space separated values of the first name, last name, age and sex, respectively.
Constraints
Output Format
Output names on separate lines in the format described above in ascending order of age.
Sample Input
3
Mike Thomson 20 M
Robert Bustle 32 M
Andria Bustle 30 F
Sample Output
Mr. Mike Thomson
Ms. Andria Bustle
Mr. Robert Bustle
Concept
For sorting a nested list based on some parameter, you can use the itemgetter library. You can read more about ithere.
Decorators 2 - Name Directory - Hacker Rank Solution
Problem Tester's code :
def formal(ns):
first,last,age,sex = ns
return ('Mr. ' if sex == 'M' else 'Ms. ') + first + ' ' + last
def std(f):
def inner(ns):
return map(formal, f(ns))
return inner
@std
def nsort(ns):
return [x[1] for x in sorted(enumerate(ns), key=lambda x: (x[1][2],x[0]))]
n = int(raw_input())
for x in nsort([raw_input().split() for x in range(n)]):
print x
No comments:
Post a Comment