https://www.acmicpc.net/problem/15666
1. 아이디어
배열의 복수 조합이면서 중복 조합을 구하면 된다.
2. 문제풀이
before 변수로 중복 체크를 했고 재귀 함수와 반복문의 활용으로 간단하게 구현할 수 있다.
3. 코드
import java.io.*;
import java.util.*;
public class Main {
private static final StringBuilder sb = new StringBuilder();
private static int[] arr;
private static int[] sel;
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));
StringTokenizer st = new StringTokenizer(br.readLine());
int N = Integer.parseInt(st.nextToken());
int M = Integer.parseInt(st.nextToken());
arr = new int[N];
st = new StringTokenizer(br.readLine());
for (int i = 0; i < N; i++) {
arr[i] = Integer.parseInt(st.nextToken());
}
Arrays.sort(arr);
sel = new int[M];
combination(0, 0);
bw.write(sb.toString());
bw.flush();
}
// 중복 복수 조합?
private static void combination(int idx, int selIdx) {
if (selIdx == sel.length) {
for (int n : sel) {
sb.append(n).append(" ");
}
sb.append("\n");
return;
}
int before = 0;
for (int i = idx; i < arr.length; i++) {
if (before == arr[i]) continue;
sel[selIdx] = arr[i];
before = arr[i];
combination(i, selIdx + 1);
}
}
}
4. 후기
'코딩테스트 준비 > 백준' 카테고리의 다른 글
[백준] 9461번 - 파도반 수열 [Java] (0) | 2025.01.12 |
---|---|
[백준] 1759번 - 암호 만들기 [Java] (0) | 2025.01.12 |
[백준] 15665번 - N과 M (11) [Java] (0) | 2025.01.12 |
[백준] 15664번 - N과 M (10) [Java] (0) | 2025.01.12 |
[백준] 15663번 - N과 M (9) [Java] (0) | 2025.01.12 |