[백준 15664] N과 M (10)

Junyoung Park·2022년 7월 6일
0

코딩테스트

목록 보기
492/631
post-thumbnail

1. 문제 설명

N과 M (10)

2. 문제 분석

중복을 허용하지 않는 조합

3. 나의 풀이

import sys

n, m = map(int, sys.stdin.readline().rstrip().split())
numbers = list(map(int, sys.stdin.readline().rstrip().split()))
numbers.sort()
check = [False for _ in range(n)]
answers = set()

def DFS(start_idx, cnt, num):
    if cnt == m:
        answers.add(tuple(num))
        return

    for i in range(start_idx, n):
        if not check[i]:
            check[i] = True
            DFS(i, cnt + 1, num + [numbers[i]])
            check[i] = False

DFS(0, 0, [])
answers = list(answers)
answers.sort()
for answer in answers:
    print(*answer)
profile
JUST DO IT

0개의 댓글