백준 2562번: 최댓값 (구현)
https://www.acmicpc.net/problem/2562
문제
9개의 서로 다른 자연수가 주어질 때, 이들 중 최댓값을 찾고 그 최댓값이 몇 번째 수인지를 구하는 프로그램을 작성하시오.
예를 들어, 서로 다른 9개의 자연수
3, 29, 38, 12, 57, 74, 40, 85, 61
이 주어지면, 이들 중 최댓값은 85이고, 이 값은 8번째 수이다.
입력
첫째 줄부터 아홉 번째 줄까지 한 줄에 하나의 자연수가 주어진다. 주어지는 자연수는 100 보다 작다.
출력
첫째 줄에 최댓값을 출력하고, 둘째 줄에 최댓값이 몇 번째 수인지를 출력한다.
예제 입력
3
29
38
12
57
74
40
85
61
예제 출력
85
8
풀이
num_list = []
for i in range(9):
num = int(input())
num_list.append(num)
print(max(num_list))
print(num_list.index(max(num_list))+1)
일단, 9번의 반복을 통해 9개의 수를 받는다는것을 생각해야합니다.
num_list = []
for i in range(9):
num = int(input())
num_list.append(num)
그럴려면, 먼저 9개의 수를 입력을 받을 리스트를 명시한 다음에, 반복문을 구성하여, 입력받은 수를 하나씩 num_list 에 저장해야합니다.
반복문 안에 수를 임시로 입력 받을수 있는 num 이라는 변수를 지정하여 임시로 입력받은 수를 저장한후, .append method를 통해 입력받은 수 num을 num_list에 추가합니다.
그후, 출력해야 할 결과값은 2개입니다.
1. 입력받은 수 중 최대값, 2. 입력받은 최대값의 위치
print(max(num_list))
print(num_list.index(max(num_list))+1)
최대값을 출력하는 것은 간단합니다. max method를 사용하여 num_list 안에 있는 값중 최대값을 출력해 주면 됩니다.
그 다음, 최대값의 위치를 출력해줘야 하는데, 이때, 리스트의 index는 0부터 시작하는것을 알아야 합니다.
근데, 예시 출력값을 보면, 85의 위치는 8번째라고 표시되어 있습니다.
즉, 1부터 시작하는것이죠. 그러므로 + 1을 해줌으로서 index를 1부터 시작하는 위치로 변환합니다.
'⌨️ Python & Algorithm' 카테고리의 다른 글
[백준] 2884번: 알람 시계 (by Python / 파이썬) (0) | 2025.01.26 |
---|---|
[백준] 2439번: 별 찍기 - 2 (by Python / 파이썬) (0) | 2025.01.23 |
[백준] 2753번 : 윤년 (by Python / 파이썬) (0) | 2025.01.22 |
[백준] 2475번 : 검증수 (by Python / 파이썬) (0) | 2025.01.21 |
[백준] 10871번 : X보다 작은수 (by Python / 파이썬) (0) | 2025.01.21 |