반응형
15650번: N과 M (2) (acmicpc.net)
15650번: N과 M (2)
한 줄에 하나씩 문제의 조건을 만족하는 수열을 출력한다. 중복되는 수열을 여러 번 출력하면 안되며, 각 수열은 공백으로 구분해서 출력해야 한다. 수열은 사전 순으로 증가하는 순서로 출력해
www.acmicpc.net
풀이
- 1 ~ N 까지 수 중에서 중복없이 M개씩 고른 오름차순 조합을 사전순 증가로 출력하는 문제이다.
- 파이썬의 itertools 에서 combinations 을 import 하여 쉽게 조합을 구현 할 수 있다.
- 파이썬의 combinations 으로 만든 조합들은 처음부터 사전순 증가와 오름차순으로 만들어지므로 출력만 하면 된다.
import sys
from itertools import combinations
n , m = map(int, sys.stdin.readline().split(" "))
stack = []
for i in range(1,n+1):
stack.append(i)
ans = list(combinations(stack, m))
if m == 1:
for t in range(0, len(ans)):
s = list(ans[t])
print(s[0])
else:
for t in range(0,len(ans)):
s = list(ans[t])
for u in range(0,len(s)-1):
print(s[u],end=" ")
print(s[len(s)-1])
반응형
'코딩 > 백준' 카테고리의 다른 글
알고리즘 - Python / 백준 - 15654번 : N과 M (5) (0) | 2021.09.20 |
---|---|
알고리즘 - Python / 백준 - 15652번 : N과 M (4) (0) | 2021.09.20 |
알고리즘 - Python / 백준 - 1758번 : 알바생 강호 (0) | 2021.09.19 |
알고리즘 - Python / 백준 - 1041번 : 주사위 (0) | 2021.09.08 |
알고리즘 - Python / 백준 - 2023번 : 신기한 소수 (0) | 2021.09.07 |