반응형

그리디 알고리즘은 매 단계에서 가장 좋아 보이는 선택을 하는 방법론입니다. 최적화 문제를 해결하는 데 사용되지만, 항상 최적의 해를 보장하지는 않습니다.

주요 개념

  • 욕심쟁이 방법: 현재 상황에서 가장 좋은 선택을 반복적으로 수행.
  • 최적해 보장 조건: 선택한 해가 전체 문제의 최적해와 같음을 보장하려면 문제 자체가 특정 조건을 만족해야 함.

동전 바꾸기 문제

문제 설명

어떤 금액을 동전으로 바꿀 때 동전의 수를 최소화하는 문제입니다.

예시

  • 동전 종류: 100원, 50원, 10원
  • 금액: 200원
  • 최적해: 100원 2개
  • 160원짜리 동전 추가 시 그리디 알고리즘은 160원 1개 + 10원 4개를 반환, 최적해는 아님.

해결 방법: DP(Dynamic Programming)로 변형

  • 각 금액에 대해 최소 동전 수를 배열에 저장하며 점진적으로 계산.

부분 배낭 문제

문제 설명

무게 제한이 있는 배낭에 최대 가치를 넣는 문제입니다.

  • 시간 복잡도: O(nlogn)
  • 가치가 높은 순서로 아이템을 배낭에 추가, 공간 부족 시 분할 추가.

활용

  • 원자재 절단 최적화
  • 금융 포트폴리오 구성
  • Merkle-Hellman 배낭 암호 시스템

집합 커버 문제

문제 설명

최소한의 부분집합으로 전체 집합 U를 덮는 문제입니다.

예시: 신도시 학교 배치

  • 전체 집합 U = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10}
  • 부분집합 S1 = {1, 2, 3, 8}, S2 = {1, 2, 3, 4, 8}, S6 = {5, 6, 7, 9, 10}
  • 최적해: S2와 S6 선택 (U = S2 \u222a S6)

그리디 근사법

  1. 전체 집합 U에서 부분집합 탐색
  2. 가장 많은 커버를 제공하는 부분집합 선택
  3. 선택된 부분집합을 U에서 제거
  4. 반복 후 선택된 부분집합 출력
  • 시간 복잡도: O(n^3)

활용

  • 도시 계획 (공공 기관 배치)
  • CCTV 최적 배치
  • 바이러스 탐지, 기업 채용, 정보 검색 등

작업 스케줄링 문제

예시 1: 공장 기계 스케줄링

  • 기계 수: 3
  • 작업 시간 배열: {[0,2], [1,6], [1,5], [3,7], [5,9], [6,8], [7,8]}
  • 종료 시간이 가장 빠른 기계에 작업 부여

예시 2: 회의실 배정

  • 종료 시간이 가장 이른 회의부터 배정
  • 최적해 보장

활용

  • 생산 공정, 강의실 배정, 태스크 스케줄링 등
  • 시간 복잡도: O(nlogn) + O(mn)

허프만 압축

원리

  1. 각 문자의 빈도수를 기반으로 이진 트리 생성.
  2. 왼쪽 자식엔 0, 오른쪽 자식엔 1을 할당.

예시

  • 문자 빈도: A: 450, T: 90, G: 120, C: 270
  • 허프만 코드 생성 후 압축:
    • 압축된 파일 크기: 1,620 bits
    • 아스키 코드 파일 크기: 7,440 bits
    • 압축률: 21.8%

복호화

  • 압축된 데이터: 10110010001110101010100
  • 복호화 결과: G T T A C G A G A T

활용

  • 팩스, 대용량 데이터 저장, MP3 압축
  • 정보 이론에서 엔트로피 계산
  • 시간 복잡도: O(nlogn)

결론

그리디 알고리즘은 단순하면서도 다양한 문제에 활용 가능합니다. 하지만 최적의 해를 보장하지 않는 경우도 있으므로, 문제의 특성을 잘 파악하고 필요에 따라 다른 알고리즘(DP 등)을 적용해야 합니다. 활용 예시는 도시 계획, 생산 공정 최적화, 데이터 압축 등 다양합니다.

반응형

+ Recent posts