[백준] 2566번 최댓값 | 파이썬 Python

문제

<그림 1>과 같이 9×9 격자판에 쓰여진 81개의 자연수 또는 0이 주어질 때, 이들 중 최댓값을 찾고 그 최댓값이 몇 행 몇 열에 위치한 수인지 구하는 프로그램을 작성하시오.

예를 들어, 다음과 같이 81개의 수가 주어지면 이들 중 최댓값은 90이고, 이 값은 5행 7열에 위치한다.

 

입력

첫째 줄부터 아홉 번째 줄까지 한 줄에 아홉 개씩 수가 주어진다. 주어지는 수는 100보다 작은 자연수 또는 0이다.

 

출력

첫째 줄에 최댓값을 출력하고, 둘째 줄에 최댓값이 위치한 행 번호와 열 번호를 빈칸을 사이에 두고 차례로 출력한다. 최댓값이 두 개 이상인 경우 그 중 한 곳의 위치를 출력한다.

 

예제

 

나의 풀이

table = []
max_num = 0
max_row = 0

for i in range(9):
	temp = list(map(int, input().split()))
	table.append(temp)
	temp_max = max(temp)

	if temp_max > max_num:
		max_num = temp_max
		max_row = i

max_col = table[max_row].index(max_num)
print(max_num)
print(max_row + 1, max_col + 1)
  • 각 행을 `table`에 `append()`한다. `table`는 최댓값이 위치한 열을 구하는 데 사용된다.
  • 각 행마다 최댓값을 구해서 `max_num`보다 큰 경우에만 `max_num`의 값과 `max_row`의 값을 바꾼다.
  • 최댓값이 위치하는 열은 `table[max_row].index(max_num)`로 접근한다.