일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- 알고리즘
- OS
- 파이썬
- Python
- 비동기
- 자바
- useState
- python algorithm
- 코드스테이츠
- algorithm
- node.js
- 자료구조
- 파이썬 알고리즘 인터뷰
- 개발공부
- typeScript
- Operating System
- java
- 컴퓨터공학
- REACT
- codestates
- Computer Science
- 운영체제
- 자바스크립트
- context switching
- JavaScript
- execution context
- Zerobase
- react 기초
- 글또
- 프로그래머스
Archives
- Today
- Total
Back to the Basics
[Programmers-python algorithm] - 5강 본문
Computer Science/Algorithm & Data Structure
[Programmers-python algorithm] - 5강
9Jaeng 2021. 7. 4. 21:22728x90
5강 재귀 알고리즘 (recursive algorithms) - 응용
문제의 종류에 따라 재귀 알고리즘을 적용하여 알고리즘을 간단하고 이해하기 쉽게 서술할 수 있다는 장점이 있다.
하지만 일반적으로 주어진 문제에 대해서 반복적인 알고리즘이 제귀적인 알고리즘보다 시작적 효율이 더 높다.
그럼에도 불구하고 사람의 생각을 코드로 옮겨놓을 수 있다는 특성 때문에 tree와 같은 자료구조를 이용하는 알고리즘에는 매우 직관적으로 적용할 수 있는 경우가 많다.
재귀알고리즘을 이용하여 다음의 문제들을 풀 수 있다.
(1) 조합의 수 (n 개의 서로 다른 원소애서 m개를 택하는 경우의 수) 구하기
// Trivial case를 고려해야 한다.
// n=m 일 때와 m=0일 때 이외에 재귀를 사용하여 구현한다.
def combi(n,m):
if n==m:
return 1
elif m==0:
return 1
else
return combi(n-1,m)+combi(n-1,m-1)
(2) 하노이의 탑 (크기 순서로 쌓여 있는 원반을 한 막대에서 다른 막대로 옮기기)
하노이의 탑은 추후 올릴 예정....
(3) 피보나치 수열
from math import factorial as f
def combi(n,m):
return f(n)/f(m)*f(n-m)
재귀함수의 효율성과 관련하여 위의 피보나치 수열을 예로 들어보자.
fibo(4) = fibo(3)+fibo(2) fibo(4)를 계산하기 위해 아래의 연산들을 진행하게 된다.
- fibo(3) = fibo(2) + fibo(1)
- fibo(2) = fibo(1) + fibo(0)
- fibo(2) = fibo(1) + fibo(0)
총 9번의 함수를 호출한다.
(4) Binary Search
[Programmers-python algorithm] - 3강 에 포스팅 했던 Binary Search도
재귀적인 방법으로 구현이 가능하다.
아래의 링크를 통해 확인이 가능하다.
5-binsrrch.py
728x90
'Computer Science > Algorithm & Data Structure' 카테고리의 다른 글
[자료구조/알고리즘]재귀 - JSON - Serialize & Deserialize (0) | 2021.09.10 |
---|---|
[Algorithm] - 제곱근 , 소수점 구하기 (0) | 2021.08.31 |
[Programmers-python algorithm] - 4강 (0) | 2021.07.03 |
[Programmers-python algorithm] - 3강 (0) | 2021.07.03 |
[Programmers-python algorithm] - 1,2강 (0) | 2021.07.03 |
Comments