본문 바로가기

파이썬 알고리즘 풀이

54)조합 구하기

문제

1부터 N까지 번호가 적힌 구슬이 있습니다.

 

이 중 M개를 뽑는 방법의 수를 출력하는 프로그램을 작성하기

 

조건

 

제한사항

첫 번째 줄에 자연수 N(3<=N<=10)과 M(2<=M<=N) 이 주어집니다.

 

첫 번째 줄에 결과를 출력합니다. 맨 마지막 총 경우의 수를 출력합니다.

 

출력순서는 사전순으로 오름차순으로 출력합니다.

 

문제풀이

def go(L, s):
  global cnt

  if L==M:
    for j in range(L):
      print(res[j], end=' ')
    print()
    cnt+=1
  else:
    for i in range(s, N+1):
      res[L]=i
      go(L+1, i+1)

N, M=map(int, input().split())
res=[0]*(N+1)
cnt=0
go(0, 1)
print(cnt)

 

'파이썬 알고리즘 풀이' 카테고리의 다른 글

56)인접행렬(가중치 방향그래프)  (0) 2021.11.08
55)수들의 조합  (0) 2021.11.08
53)수열 추측하기  (0) 2021.11.04
52)순열 구하기  (0) 2021.11.04
51)동전 교환  (0) 2021.11.04