업데이트:

❓ 문제


문제

문제

✏ 나의 풀이


1
2
3
4
5
6
7
8
n, _ = map(int, input().split())
result = []

# 각 행의 최솟값을 구해 result 배열에 추가하는 것을 n번 반복
exec('result += [min(map(int, input().split()))];' * n)

# 그 중 최댓값 출력
print(max(result))

💡 문제 해결 아이디어


각 행마다 가장 작은 수를 찾은 뒤에 그 수 중에서 가장 큰 수를 찾으면 된다.

각 행에서 가장 작은 수를 찾은 다음 그 수 중에서 가장 큰 수를 찾는 방식으로 문제를 해결할 수 있다.

이 문제를 해결하기 위해서는 리스트에서 가장 작은 원소를 찾아주는 min() 함수를 이용할 수 있거나, 2중 반복문 구조를 이용할 수 있어야 한다.

✔️ 파이썬 답안 예시 : min()


1
2
3
4
5
6
7
8
9
10
11
12
13
# N, M을 공백을 기준으로 구분하여 입력 받기
n, m = map(int, input().split())

result = 0
# 한 줄씩 입력 받아 확인하기
for i in range(n):
    data = list(map(int, input().split()))
    # 현재 줄에서 '가장 작은 수' 찾기
    min_value = min(data)
    # '가장 작은 수'들 중에서 가장 큰 수 찾기
    result = max(result, min_value)

print(result) # 최종 답안 출력

✔️ 파이썬 답안 예시 : 2중 반복문


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
# N, M을 공백을 기준으로 구분하여 입력 받기
n, m = map(int, input().split())

result = 0
# 한 줄씩 입력 받아 확인하기
for i in range(n):
    data = list(map(int, input().split()))
    # 현재 줄에서 '가장 작은 수' 찾기
    min_value = 10001
    for a in data:
        min_value = min(min_value, a)
    # '가장 작은 수'들 중에서 가장 큰 수 찾기
    result = max(result, min_value)

print(result) # 최종 답안 출력

💬 풀이 평가


파이썬 함수에 너무 의존하지 말고 다양한 방법으로 푸는 연습을 해야겠다.

Notice: 이 게시물은 한빛미디어의 이것이 코딩 테스트다 교재를 참고하였습니다.

댓글남기기