https://www.acmicpc.net/problem/15664
N개의 자연수 중에서 M개를 고른 수열중복되는 값이 존재하는 N개의 자연수 중에서 조합을 찾는 문제입니다.
st = new StringTokenizer(br.readLine());
nums = new int[n];
for (int i = 0; i < n; i++) nums[i] = Integer.parseInt(st.nextToken());
Arrays.sort(nums);
private static void dfs(int idx, int start) {
if (idx == m) {
for (int i : li) sb.append(i).append(" ");
sb.append("\n");
return;
}
int prev = 0; // 동일 레벨에서 중복값을 판단하는 변수
for (int i = start; i < n; i++) {
if (prev != nums[i]) { // 같은 값을 넣으려고 하면 안 됨
li[idx] = nums[i];
prev = nums[i]; // 값 할당
dfs(idx + 1, i + 1); // 재귀
}
}
}
visited 배열은 필요하지 않습니다.import java.io.*;
import java.util.*;
public class Main_15664 {
static StringBuilder sb = new StringBuilder();
static int n, m;
static int[] li, nums;
private static void dfs(int idx, int start) {
if (idx == m) {
for (int i : li) sb.append(i).append(" ");
sb.append("\n");
return;
}
int prev = 0;
for (int i = start; i < n; i++) {
if (prev != nums[i]) {
li[idx] = nums[i];
prev = nums[i];
dfs(idx + 1, i + 1);
}
}
}
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
StringTokenizer st = new StringTokenizer(br.readLine());
n = Integer.parseInt(st.nextToken());
m = Integer.parseInt(st.nextToken());
st = new StringTokenizer(br.readLine());
nums = new int[n];
for (int i = 0; i < n; i++) nums[i] = Integer.parseInt(st.nextToken());
Arrays.sort(nums);
li = new int[m];
dfs(0, 0);
System.out.println(sb.toString());
}
}