[이.코.테] 3. 숫자 카드 게임

2023. 6. 28. 11:45Algorithm/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