❓ 문제 ❓
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;
}