DeJa
Techvu
DeJa
전체 방문자
53,226
오늘
6
어제
56
  • Techvu (60)
    • DesignPatterns (3)
      • 생성 (0)
      • 구조 (1)
      • 행동 (2)
    • Refactoring (0)
    • DataStructures (0)
    • Algorithms (24)
      • 기본 지식 (12)
      • 문제 풀이 (12)
    • OOP (0)
    • TDD (2)
    • DDD (0)
    • Programming Languages (9)
      • Java (9)
      • Kotlin (0)
    • Spring (1)
    • JPA (7)
    • Web (1)
      • 기본 지식 (1)
      • 실무 경험 (0)
    • CS (12)
      • Network (1)
      • OS (8)
      • DataBase (3)
      • Server (0)
    • Git (1)
    • Conferences (0)

블로그 메뉴

  • 홈
  • 태그
  • 미디어로그
  • 위치로그
  • 방명록

공지사항

  • Study
  • GitHub
  • Medium Blog

인기 글

  • 스키마(Schema)
    2022.01.08
    스키마(Schema)
  • 깃허브 사용 방법
    2021.12.15
    깃허브 사용 방법
  • 자바 버전별 역사 및 특징
    2022.01.12
    자바 버전별 역사 및 특징
  • 세그멘테이션과 페이징
    2021.12.17
    세그멘테이션과 페이징
  • 동시성 이슈(Concurrency Issue)
    2022.03.20
    동시성 이슈(Concurrency Issue)

태그

  • web
  • 알고리즘
  • java
  • CS
  • DATABASE
  • 디자인패턴
  • TDD
  • Spring
  • network
  • OS
  • JPA

최근 댓글

  • 정말 잘 정리된 글! 잘 읽고 갑니다
    qwer
  • 글 잘읽고 가요.
    아이폰
  • 컴파일러자체에서 꼬리재귀를 지원하지 않으니 static으로⋯
    aaa
  • 압도적 감사
    ㅇㅇㅇ

최근 글

  • Write a test code right now
    2022.03.24
    Write a test code right now
  • 동시성 이슈(Concurrency Issue)
    2022.03.20
    동시성 이슈(Concurrency Issue)
  • POJO, JavaBean, Entity, VO, DTO
    2022.02.08
    POJO, JavaBean, Entity, VO, DTO
  • TDD with Agile
    2022.02.05
    TDD with Agile
  • Java Stream 기초
    2022.01.23
    Java Stream 기초

티스토리

hELLO · Designed By 정상우.
DeJa

Techvu

조합(Combination)
Algorithms/기본 지식

조합(Combination)

2022. 1. 3. 21:45
728x90

조합(Combination)

이번 시간에는 DFS 로 조합을 구현하는 방법을 배워보자.

N 명 중 R 명을 뽑는 경우의 수

nCr 은 n 개의 원소를 갖는 집합에서 r 개의 부분 집합을 고르는 경우의 수를 의미하므로 부분 집합과도 관련이 있다.

구현

// 조합(Combination) : nCr = n-1Cr-1 + n-1Cr
// n 명 중에서 r 명을 뽑는 경우
// 5C3 = 4C2 + 4C3
public class Main {

    static int[][] store = new int[35][35];

    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        System.out.println(combinationByDfsWithMemoization(sc.nextInt(), sc.nextInt()));
    }

    // 메모이제이션
    static int combinationByDfsWithMemoization(int n, int r) {
        if(store[n][r] > 0) {
            return store[n][r];
        }
        if(n == r || r ==0) {
            return 1;
        } else {
            return store[n][r] = combinationByDfsWithMemoization(n - 1, r - 1) + combinationByDfsWithMemoization(n - 1, r);
        }
    }
}

조합

DFS 를 이용하여 부분 집합 을 구현하는 방법을 모른다면 해당 링크를 통해서 먼저 배우는 것이 좋다.

구현

/**
 * 조합을 이용하여 부분집합 구하기
 * @param arr 원소를 담고 있는 배열
 * @param visited 해당 원소를 사용하는지 여부
 * @param currentIndex 현재 인덱스
 * @param r 뽑을 개수
 */
 static void combinationByDfs(int[] arr, boolean[] visited, int currentIndex, int r) {
     if(r == 0) {
         // r == 0 일때, visited 가 true 인 부분집합을 이용하여 원하는 로직 구현
         logic(arr, visited);
         return;
     }
     if(currentIndex == arr.length) {
         return;
     } else {
         visited[currentIndex] = true; // currentIndex 에 해당하는 원소를 사용한다라는 의미
         combinationByDfs(arr, visited, currentIndex + 1, r - 1); // currentIndex 에 해당하는 원소를 사용하면 R 값을 -1

         visited[currentIndex] = false; // currentIndex 에 해당하는 원소를 사용하지 않는다라는 의미
         combinationByDfs(arr, visited, currentIndex + 1, r); // currentIndex 에 해당하는 원소를 사용하지 안으면 R 값 유지
    }
}
728x90
저작자표시 비영리 동일조건
  • 카카오스토리
  • 트위터
  • 페이스북

'Algorithms > 기본 지식' 카테고리의 다른 글

LIS(최장 증가 부분 수열)  (0) 2022.01.11
부분 집합 구하기(DFS)  (0) 2022.01.03
깊이 우선 탐색(DFS)  (0) 2022.01.03
위상 정렬  (0) 2021.12.14
신장 트리와 크루스칼 알고리즘  (0) 2021.12.13
    'Algorithms/기본 지식' 카테고리의 다른 글
    • LIS(최장 증가 부분 수열)
    • 부분 집합 구하기(DFS)
    • 깊이 우선 탐색(DFS)
    • 위상 정렬
    알고리즘
    DeJa
    DeJa
    Tech Blog
    댓글쓰기
    LIS(최장 증가 부분 수열)
    다음 글
    LIS(최장 증가 부분 수열)
    부분 집합 구하기(DFS)
    이전 글
    부분 집합 구하기(DFS)

    티스토리툴바