What I Learned/Algorithm Practice
[백준 - python] 15651번: N과 M (3)
Interrobang
2022. 12. 13. 20:51
문제 링크
15651번: N과 M (3)
한 줄에 하나씩 문제의 조건을 만족하는 수열을 출력한다. 중복되는 수열을 여러 번 출력하면 안되며, 각 수열은 공백으로 구분해서 출력해야 한다. 수열은 사전 순으로 증가하는 순서로 출력해
www.acmicpc.net
문제 풀이
n, m = map(int, input().split())
case = []
def recursive():
if len(case) == m:
print(' '.join(map(str, case)))
return
for i in range(1, n + 1):
case.append(i)
recursive()
case.pop()
recursive()

*key point: 15649번 문제에서 continue 시키는 부분을 없애면 조건을 만족시킬 수 있다.
*comment: 기본 형태를 잘 짜두게 되면 응용하기 매우 편하다.