Java - Combination
                                            
                                                
                                                
                                                
                                                
                                                
                                                 1234 단어  combination조합combination
                    
조합
- n 개의 숫자 중에서 r 개의 수를 순서 없이 뽑는 경우이다.
- 순열에서 중복 제거한 것과 같다.
[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;
    }
  }- start 변수를 기준으로 탐색을 시작한다.
 start가 0으로 시작해 for문을 돌면서 방문 후 뽑은 노드는 true 표시를 하고 뽑지 않으면 다시 false로 둔다.


- 1, 3을 뽑았을 때 [true, false, true, false] 임을 확인할 수 있다.
Author And Source
이 문제에 관하여(Java - Combination), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://velog.io/@donsco/Java-Combination저자 귀속: 원작자 정보가 원작자 URL에 포함되어 있으며 저작권은 원작자 소유입니다.
                                
                                
                                
                                
                                
                                우수한 개발자 콘텐츠 발견에 전념
                                (Collection and Share based on the CC Protocol.)