Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- Git
- AWS
- Bruteforce
- stack&que
- TDD
- permutations
- HTTP 완벽 가이드
- dictionary
- SQL
- Gunicorn
- pytest
- combinations
- ws
- algorithm
- Django
- utils
- 백준
- Unit Testing
- greedy
- Q objects
- Stack
- Query
- Programmers
- was
- Python
- stateless
- stateful
- postreSQL
- codecov
- ORM
Archives
- Today
- Total
해피 코딩!
순열과 조합 - combinations, permutations 본문
조합
조합이란 n개의 원소를 사용해서 순서의 관계없이 r개의 배열로 나타내는 것을 말한다.
조합은 순서가 없어 원소의 종류가 같으면 다같은 배열로 나타낸다.
combinations
def combinations(iterable, r):
# combinations('ABCD', 2) --> AB AC AD BC BD CD
# combinations(range(4), 3) --> 012 013 023 123
pool = tuple(iterable)
n = len(pool)
if r > n:
return
indices = list(range(r))
yield tuple(pool[i] for i in indices)
while True:
for i in reversed(range(r)):
if indices[i] != i + n - r:
break
else:
return
indices[i] += 1
for j in range(i+1, r):
indices[j] = indices[j-1] + 1
yield tuple(pool[i] for i in indices)
순열
순열은 n개의 원소를 이용해서 순서를 정해 r개의 배열로 나타내는 것을 말한다.
순열은 순서가 있기 때문에 원소의 종류가 같아도 순서가 다르면 다른 배열이 된다.
permutations
permutations 공식문서
보통은 for문을 이용하여 permutations
을 구현합니다.
파이썬에서는
itertools.permutation를 이용하면, for문을 사용하지 않고도 순열을 구할 수 있습니다.
import itertools
pool = ['A', 'B', 'C']
print(list(map(''.join, itertools.permutations(pool)))) # 3개의 원소로 수열 만들기
print(list(map(''.join, itertools.permutations(pool, 2)))) # 2개의 원소로 수열 만들기
'알고리즘' 카테고리의 다른 글
[백준] 동전 0 (0) | 2020.12.23 |
---|---|
[프로그래머스] 큰 수 만들기 (0) | 2020.12.19 |
[프로그래머스] 피보나치 수 (0) | 2020.12.17 |
그래프 기본 탐색 알고리즘 - BFS, DFS (0) | 2020.12.13 |
[백준] 요세푸스 문제0 (0) | 2020.12.12 |
Comments