[1, 2, 3] 배열에서. 2개의 수를 순서 없이 뽑으면 다음과 같다.
[1, 2]
[1, 3]
[2, 3]
순열과 달리 조합은 r 을 유지할 필요 없이 숫자를 하나 뽑을 때마다 r을 하나씩 줄여준다.
r==0 일 때 r 개의 숫자를 뽑은 경우이다.
/**
* @param arr 배열
* @param visited 방문한 노드
* @param start 시작할 노드
* @param n 배열의 길이
* @param r 조합의 길이
*/
static void com1(int[] arr, boolean[] visited, int start, int n, int r) {
//
if (r == 0) {
print(arr, visited, n);
return;
}
for (int i = start; i < n; i++) {
visited[i] = true;
com1(arr, visited, i + 1, n, r - 1);
visited[i] = false;
}
}