Leta Learns

[Python] 백준 15649번 - N과 M (1) 본문

Coding/백준

[Python] 백준 15649번 - N과 M (1)

leta 2022. 2. 24. 11:18

문제 https://www.acmicpc.net/problem/15649

 

15649번: N과 M (1)

한 줄에 하나씩 문제의 조건을 만족하는 수열을 출력한다. 중복되는 수열을 여러 번 출력하면 안되며, 각 수열은 공백으로 구분해서 출력해야 한다. 수열은 사전 순으로 증가하는 순서로 출력해

www.acmicpc.net

 

보물 문제만 풀기에는 조금 양심에 찔려서 어려워했었던 재귀, 백트래킹 파트 연습하려고 n과 m 하나 풀었다.

시간이 많이 걸리진 않았지만 연습이 많이 안 되어있는 파트라서 쉽진 않았다.

백트래킹 개념 한 번 더 공부하고 풀었다.

 

import sys
input = sys.stdin.readline

def dfs(d):
    if d == m:
        print(*ans)
        return
    
    for i in range(1, n+1):
        if i not in ans:
            ans.append(i)
            dfs(d+1)
            ans.pop()
            

n, m = map(int, input().split())
ans = []
dfs(0)

Comments