https://www.acmicpc.net/problem/15651
N과 MN까지 자연수 중에서 M개를 고른 수열중복 순열을 구하는 문제
구할 수 있는 모든 경우를 출력하면 됩니다.
private static void dfs(int idx) {
if (idx == m) {
for (int i : li) sb.append(i).append(" ");
sb.append("\n");
return;
}
for (int i = 1; i <= n; i++) {
li[idx] = i; // i번째 수 삽입
dfs(idx + 1); // 재귀
}
}
재귀를 통해 모든 수를 넣어 줍니다.
import java.io.*;
import java.util.*;
public class Main {
static StringBuilder sb = new StringBuilder();
static int n, m;
static int[] li;
private static void dfs(int idx) {
if (idx == m) {
for (int i : li) sb.append(i).append(" ");
sb.append("\n");
return;
}
for (int i = 1; i <= n; i++) {
li[idx] = i;
dfs(idx + 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());
li = new int[m];
dfs(0);
System.out.println(sb.toString());
}
}