반응형
문제
어떤 반에 있는 학생들의 생일이 주어졌을 때, 가장 나이가 적은 사람과 가장 많은 사람을 구하는 프로그램을 작성하시오.
입력
첫째 줄에 반에 있는 학생의 수 n이 주어진다. (1 ≤ n ≤ 100)
다음 n개 줄에는 각 학생의 이름과 생일이 "이름 dd mm yyyy"와 같은 형식으로 주어진다. 이름은 그 학생의 이름이며, 최대 15글자로 이루어져 있다. dd mm yyyy는 생일 일, 월, 연도이다. (1990 ≤ yyyy ≤ 2010, 1 ≤ mm ≤ 12, 1 ≤ dd ≤ 31) 주어지는 생일은 올바른 날짜이며, 연, 월 일은 0으로 시작하지 않는다.
이름이 같거나, 생일이 같은 사람은 없다.
출력
첫째 줄에 가장 나이가 적은 사람의 이름, 둘째 줄에 가장 나이가 많은 사람 이름을 출력한다.
예제 입력 1
5 Mickey 1 10 1991 Alice 30 12 1990 Tom 15 8 1993 Jerry 18 9 1990 Garfield 20 9 1990
예제 출력 1
Tom Jerry
문제 해석
각 학생의 이름과 생일을 "이름 dd mm yyyy"와 같은 형식으로 입력받은 후 공백을 기준으로 나누어 각각 저장합니다.
이때 dd, mm, yyyy의 자료형이 문자열로 취급되기 때문에 map()을 이용하여 int형(정수)로 저장합니다.
[연, 월, 일, 이름]을 미리 만들어둔 info_list에 추가하고 sort 함수를 통해 정렬하면 생년월일이 오름차순으로 정렬됩니다.가장 나이가 적은 사람의 이름은 리스트의 마지막에 있으므로 index=-1이고, 그 중 이름의 index=3입니다.가장 나이가 많은 사람의 이름은 리스트의 처음에 있으므로 index=0이고, 마찬가지로 이름의 index=3입니다.
코드
info_list=[]
for i in range(int(input())):
name,date,month,year = input().split()
date,month,year = map(int,(date,month,year))
info_list.append((year,month,date,name))
info_list.sort()
print(info_list[-1][3])
print(info_list[0][3])
코드 실행
반응형