알고리즘/백준

[백준] 15652번 N과 M (4) (파이썬)

알감자 2021. 12. 29. 21:28
 

15652번: N과 M (4)

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

www.acmicpc.net

 

코드

n, m = map(int, input().split())

num_list = [i+1 for i in range(n)]
check_list = [False]*n
answer = []

def count(cnt):
    if cnt == m:
        print(*answer)
        return
    for i in range(n):
        if check_list[i] == True:
            continue
        answer.append(num_list[i])

        count(cnt+1)
        check_list[i] = True
        answer.pop()
        for j in range(i+1,n):
            check_list[j] = False

count(0)