[1,1] [2,2]를 허용하여 출력 & [1,2] [2,1] 같은것으로 봄-> 중복 허용 조합


import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.Arrays;
import java.util.StringTokenizer;
public class Main {
static int N,M;
static StringBuilder sb = new StringBuilder();
public static void main(String[] args) throws IOException {
// 고른 수열은 비내림차순이어야 한다.
//->1,1도 출력, [1,2] [2,1]을 같은것으로봄 중복을 허용하는 조합.
//조합에서 중복을 허용한다? [1,1] [2,2] 가능
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
StringTokenizer st = new StringTokenizer(br.readLine()," ");
N = Integer.parseInt(st.nextToken());
M = Integer.parseInt(st.nextToken());
int arr [] = new int [N];
for (int i = 1; i <=N ; i++) {
arr[i-1] = i;
}
// System.out.println(Arrays.toString(arr));
combination(arr,new int[M],0,0);
System.out.println(sb);
}
private static void combination(int[] arr, int[] sel, int idx, int k) {
if(k==M) {
for (int i = 0; i < M; i++) {
sb.append(sel[i]).append(' ');
}sb.append('\n');
return;
}
for (int i = idx; i < N; i++) {
sel[k]=arr[i];
combination(arr, sel, i, k+1);
}
}
}
'Problem Solving > BOJ' 카테고리의 다른 글
백준- 2798 블랙잭 (0) | 2021.02.07 |
---|---|
백준 - 8320 직사각형을 만드는 방법 (0) | 2021.02.07 |
백준- 15651번 N과M (3) (0) | 2021.02.07 |
백준 -15650번 N과M(2) (0) | 2021.02.07 |
백준 - 15649 N과 M(1) (0) | 2021.02.07 |
댓글