[파이썬 알고리즘] 숫자 카드 게임 문제 풀이
업데이트:
❓ 문제
✏ 나의 풀이
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: 이 게시물은 한빛미디어의 이것이 코딩 테스트다 교재를 참고하였습니다.
댓글남기기