[이.코.테] 3. 숫자 카드 게임
2023. 6. 28. 11:45ㆍAlgorithm/Greedy
문제
- 숫자가 쓰인 카드들이 N x M 형태로 놓여 있다. 이때 N은 행의 개수, M은 열의 개수
- 먼저 뽑고자 하는 카드가 포함되어 있는 행을 선택한다.
- 그다음 선택된 행에 포함된 카드들 중 가장 숫자가 낮은 카드를 뽑아야 한다.
- 따라서 처음에 카드를 골라낼 행을 선택할 때, 이후에 해당 행에서 가장 숫자가 낮은 카드를 뽑을것을 고려하여 최종적으로 가장 높은 숫자의 카드를 뽑을 수 있도록 전략을 세워야 한다.
입력 조건
-
첫째 줄에 숫자 카드들이 놓인 행의 개수 N과 열의 개수 M이 공백을 기준으로 하여 각각 자연수로 주어진다. (1 ≤ N, M ≤ 100)
-
둘째 줄부터 N개의 줄에 걸쳐 각 카드에 적힌 숫자가 주어진다. 각 숫자는 1 이상 10000 이하의 자연수이다.
입력 예시
3 3
3 1 2
4 1 4
2 2 2
출력 예시
2
문제 설명이 조금 복잡하여 이해에 시간이 걸렸지만, 사실 내부를 뜯어 보면 그렇게 어려운 문제는 아닌 것 같습니다.
행을 선택하고 행 카드중 가장 작은 수를 선택해 출력하면 되지만, 이러한 생각의 흐름을 그대로 코드로 옮길 경우
복잡해질 수 있어, 방법을 조금 바꿨습니다.
행 기준으로 배열을 정렬하면 첫 번째 열에 해당 행의 최솟값이 오게 됩니다.
그럼 그 최솟값들을 비교하여 최솟값 중 가장 큰 수를 출력하면 되겠습니다.
소스코드 ( Java )
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
StringTokenizer st = new StringTokenizer(br.readLine());
int row = Integer.parseInt(st.nextToken());
int col = Integer.parseInt(st.nextToken());
int[][] arr = new int[row][col];
for (int i = 0; i < row; i++) {
st = new StringTokenizer(br.readLine());
for (int j = 0; j < col; j++) {
arr[i][j] = Integer.parseInt(st.nextToken());
}
}
for (int i = 0; i <row ; i++) {
Arrays.sort(arr[i]); //가장 작은 수 찾기
}
int max = 0;
for (int i = 0; i < row; i++) {
if (max < arr[i][0]){
max = arr[i][0];
}
}
System.out.println("max = " + max);
}
배열을 입력받고, Arrays.sort(arr); 로 정렬을 진행합니다.
2차원 배열에서는 sort를 진행할 수 없으므로, 간단하게 최대값을 담는 max 변수를 생성,
i 번 째 행의 최솟값과 i+1 번 째 행의 최솟값을 비교하며 큰 수를 담아서 출력하면 되겠습니다.
'Algorithm > Greedy' 카테고리의 다른 글
[이.코.테] 4. 1이 될 때까지 (0) | 2023.06.28 |
---|---|
[이.코.테] 2. 동빈이의 큰 수의 법칙 (0) | 2023.06.28 |
[이.코.테] 1. 거스름돈 문제 (0) | 2023.06.28 |