[1,1] 허용X && [1,2][2,1] 같은것으로 봄-> 중복X 조합

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 M,N;
static StringBuilder sb = new StringBuilder();
public static void main(String[] args) throws IOException {
//구할것: 1부터 N까지 자연수 중에서 중복없이 M개를 고른 수열. 고른 수열은 오름차순
//입력 N, M
//순서바꾸면 같은 수도 중복으로봄 -> 중복x조합
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
StringTokenizer st = new StringTokenizer(br.readLine()," ");
N = Integer.parseInt(st.nextToken());
int [] arr = new int [N];
M = Integer.parseInt(st.nextToken());
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+1, k+1);
}
}
}
'Problem Solving > BOJ' 카테고리의 다른 글
백준 - 8320 직사각형을 만드는 방법 (0) | 2021.02.07 |
---|---|
백준- 15652번 N과M (4) (0) | 2021.02.07 |
백준- 15651번 N과M (3) (0) | 2021.02.07 |
백준 - 15649 N과 M(1) (0) | 2021.02.07 |
백준 -1244 스위치 켜고 끄기 (0) | 2021.02.06 |
댓글