[이것이 코딩 테스트다] 숫자 카드 게임

고재욱·2021년 9월 15일
0

❓ 문제 ❓
1. 먼저 뽑고자 하는 카드가 포함되어 있는 행을 선택한다.
2. 그 다음 선택된 행에 포함된 카드들 중 가장 숫자가 낮은 카드를 뽑는다
3. 처음에 카드를 골라낼 행을 선택할 때, 이후에 해당 행에서 가장 숫자가 낮은 카드를 뽑을 것을 고려하여 최종적으로 가장 높은 숫자의 가드를 뽑을 수 있도록 전략을 세워야한다.

💯 풀이 방법 💯
그리디 방법!
각 행마다 가장 작은 수를 찾은 뒤 그 수 중 가장 큰 수가 정답

#include <iostream>
#include <algorithm>
#include <vector>
using namespace std;
int main() {
	int n, m, answer = -1;
	cin >> n >> m;
	vector<int> arr(m);
	for (int i = 0; i < n; i++) {
		for (int j = 0; j < m; j++)
			cin >> arr[j];
		sort(arr.begin(), arr.end());
		answer = max(answer, arr[0]);
	}
	cout << answer;	
}

0개의 댓글