어떤 반에 있는 학생들의 생일이 주어졌을 때, 가장 나이가 적은 사람과 가장 많은 사람을 구하는 프로그램을 작성하시오.
첫째 줄에 반에 있는 학생의 수 n이 주어진다. (1 ≤ n ≤ 100)
다음 n개 줄에는 각 학생의 이름과 생일이 "이름 dd mm yyyy"와 같은 형식으로 주어진다. 이름은 그 학생의 이름이며, 최대 15글자로 이루어져 있다. dd mm yyyy는 생일 일, 월, 연도이다. (1990 ≤ yyyy ≤ 2010, 1 ≤ mm ≤ 12, 1 ≤ dd ≤ 31) 주어지는 생일은 올바른 날짜이며, 연, 월 일은 0으로 시작하지 않는다.
이름이 같거나, 생일이 같은 사람은 없다.
첫째 줄에 가장 나이가 적은 사람의 이름, 둘째 줄에 가장 나이가 많은 사람 이름을 출력한다.
5
Mickey 1 10 1991
Alice 30 12 1990
Tom 15 8 1993
Jerry 18 9 1990
Garfield 20 9 1990
Tom
Jerry
학생들의 생년월일이 주어졌을 때 나이가 가장 적은 사람과 가장 많은 사람을 구하는 문제.
주어진 조건:
가능한 시간복잡도
timsort 알고리즘을 사용해야 하기 때문에 N log N 정렬 알고리즘으로결정
년, 월, 일을 기준으로 정렬하고, 리스트의 첫 번째와 마지막 원소를 조회하여 가장 나이 많은 사람과 가장 어린 사람을 찾기.
정렬 알고리즘으로 접근해 보겠습니다.
1회차
처음엔 람다를 사용해서 구현했으나 더 생각한 결과, 리스트나 튜플안의 요소들이 인덱스의 순서대로 비교하며 정렬하기 때문에 람다를 사용하지 않고 구현해 sort함수를 사용하면 간단하게 할 수 있어 수정함.
import sys
list_ = []
for i in range(int(sys.stdin.readline())):
name, day, month, year = sys.stdin.readline().split()
list_.append((int(year), int(month), int(day), name))
list_.sort()
print(list_[-1][3])
print(list_[0][3])