일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
- 시스템프로그래밍
- 자바입력받기
- 컴파일시스템
- 자바
- K-MOOC 단국대학교 홍보단
- TypeScript
- stringreader
- 블록체인 강의
- 티스토리챌린지
- 해시
- national instruments
- 딥러닝
- K-MOOC
- 블록체인
- 오블완
- biginteger사용법
- 디스크블록할당
- 자바스크립트
- 2차원배열정렬
- 우선순위큐
- 자바문자열구분
- 머신러닝
- html기초
- CSS 기초
- Node
- StringTokenizer
- 혁신의기술2:신뢰의미래 블록체인을 만나다
- 블록체인강의
- Entity
- 단국대학교 k-mooc
- Today
- Total
열정 실천
[알고리즘] 알고리즘 패러다임에 대해서 알아보자! 본문
알고리즘을 문제를 풀다보면 다양한 풀이방식이 존재하는데 그 풀이 방식을 알고리즘 패러다임이라고 한다.
각 패러다임은 특정 유형의 문제를 해결하는 데 특화되어 있으며, 알고리즘을 더 효율적으로 구현하는 데 도움을 준다.
주요 알고리즘 패러다임에 대해서 알아보자!
Brute Force 무차별 대입
어떤 문제에 대해서 가능한 모든 경우의 수를 시도하는 단순한 방법
직관적이고 답을 확실하게 알 수 있다. BUT 인풋이 큰 경우에는 매우 비효율적이다.
▶️ 완전 탐색, 순열/조합 문제
Backtracking 백트래킹
문제를 해결하기 위해 모든 가능한 경우의 수를 탐색하되, 해답이 될 가능성이 없는 경로는 탐색을 중단하고 이전 단계로 돌아가 다른 경로를 탐색하는 방법
▶️ N-Queen 문제, 미로 탐색
Divide and Conquer 분할 정복
문제를 더 작은 부분으로 나누고, 각 부분 문제를 해결한 뒤 결과를 합쳐 전체 문제를 해결하는 방법
부분 문제가 여전히 크다면 계속 쪼개는 방식으로 재귀적으로 접근한다.
▶️ Merge Sort, Quick Sort, 이진 탐색
Dynamic Programming 동적 계획법
문제를 부분 문제로 나누어 해결하고, 중복되는 계산을 줄이기 위해 이전 계산 결과를 저장하여 문제를 해결하는 방법
이 방법을 사용하기 위해서 만족해야할 조건 2가지가 있다.
1. 최적부분문제 구조여야한다. ( 부분 문제의 최적 해를 이용해 전체 문제를 해결할 수 있음.)
2. 중복되는 부분 문제여야한다. ( 같은 부분 문제를 여러 번 계산하는 상황 발생.)
구현 방식 또한 2가지가 있다.
1. Memoization: 재귀를 이용하여 이전 계산 결과를 저장.
2. Tabulation: 반복문을 사용해 이전 계산 결과를 테이블에 저장
▶️ 피보나치 수열, 출발지부터 목적지까지의 최단 경로 찾기(Dijkstra's Algorithm)
Greedy Algorithm 탐욕 알고리즘
미래를 고려하지 않고, 현재 상황에서 가장 최적의 선택을 반복하여 문제를 해결하는 방법
간단하고 빠르지만 완벽한 정답이 보장되지 않는다.
그리디 알고리즘이 최적의 답을 보장해주려면 문제의 조건이
1. 문제가 최적부분문제 구조여야한다.
2. 각 단계에서의 최적의 선택이 최종 답을 구하기 위한 최적의 선택이어야한다.
▶️ 최대한 적은 동전으로 거슬러 주는 문제, Kruskal's Algorithm, Prim's Algorithm (최소 신장 트리)
'개발 공부 > 코딩 문제풀이' 카테고리의 다른 글
[JAVA] 미로찾기 문제 풀 땐 DFS보다 BFS with Queue (0) | 2025.01.21 |
---|---|
[알고리즘] 프로그래머스 연속된 부분 수열의 합 :: 투포인터 with JAVA (0) | 2025.01.07 |
[우선순위큐] 프로그래머스 42627 - 디스크 컨트롤러 with Java (2) | 2024.10.14 |
[JAVA] 프로그래머스 42578 의상 - 해시 자료구조, 조합 풀이 (0) | 2024.09.04 |
[JAVA] 프로그래머스 42577 전화번호 목록 (1) | 2024.09.03 |