https://www.acmicpc.net/problem/15649
15649번: N과 M (1)
한 줄에 하나씩 문제의 조건을 만족하는 수열을 출력한다. 중복되는 수열을 여러 번 출력하면 안되며, 각 수열은 공백으로 구분해서 출력해야 한다. 수열은 사전 순으로 증가하는 순서로 출력해
www.acmicpc.net
수열을 도출하는 방법 중 하나는 백트래킹을 이용하는 방법이다. 백트래킹이란 모든 경우의 수를 살피면서 조건이 맞으면 탐색을 계속하고, 조건에 맞지 않으면 노드 하나를 되돌아가는 양상을 띈다.
n, m = map(int, input().split())
arr = []
def backtrack():
if len(arr) == m:
print(' '.join(map(str, arr)))
return
for i in range(1, n+1):
if i not in arr:
arr.append(i)
backtrack()
arr.pop()
backtrack()
'Algorithms' 카테고리의 다른 글
백준 9663. N-Queen (0) | 2022.06.20 |
---|---|
백준 15651. N과 M(3) (0) | 2022.06.17 |
백준 15650. N과 M(2) (0) | 2022.06.16 |
백준 2004. 조합 0의 개수 (0) | 2022.06.15 |
백준 1676. 팩토리얼 0의 개수 (0) | 2022.06.14 |
댓글