일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 코틀린
- Combination
- expo
- 앱
- 홈화면
- lcm
- Android
- 나머지
- 11057
- 뒤로가기
- Kotlin
- 1182
- 코테
- Python
- 11기
- 11053
- itertools
- 11054
- 매일11시
- 순열
- permutation
- 안드로이드
- 9095
- 1260
- 6603
- 괄호
- 최소공배수
- 파이썬
- 백준
- LCS
Archives
- Today
- Total
황소개발자
백준 10974 파이썬 python : 모든 순열 @@황소처럼 우직하게@@ permutations 구현할 때, 이 코드 참고하세요~ 본문
백준 문제 풀이
백준 10974 파이썬 python : 모든 순열 @@황소처럼 우직하게@@ permutations 구현할 때, 이 코드 참고하세요~
hjp845 2020. 2. 28. 07:07반응형
n = int(input())
def next_permutation(lst):
n = len(lst)
i = n - 1
while i > 0 and lst[i - 1] >= lst[i]:
i -= 1
if i <= 0:
return [-1]
# i - 1인덱스하고
j = n - 1
while lst[j] <= lst[i - 1]:
j -= 1
# j 인덱스하고 바꾼다.
tmp = lst[j]
lst[j] = lst[i - 1]
lst[i - 1] = tmp
lst = lst[:i] + sorted(lst[i:])
return lst
ans = [i for i in range(1, n + 1)]
while True:
if ans == [-1]:
break
print(' '.join(map(str, ans)))
ans = next_permutation(ans)
시간복잡도는 O(N * N!) 이다.
너무크다고?
수 범위가 8이하기에 시간초과는 나지않는다.
반응형
'백준 문제 풀이' 카테고리의 다른 글
백준 10971 파이썬 python : 외판원 순회 2 @@황소처럼 우직하게@@ 아주나이쑤 (0) | 2020.02.28 |
---|---|
백준 10819 파이썬 python : 차이를 최대로 @@황소처럼 우직하게@@ 볼륨 쵀돼료! (0) | 2020.02.28 |
백준 10973 파이썬 python : 이전 순열 @@황소처럼 우직하게@@ 스까묵자! (0) | 2020.02.28 |
백준 10972 파이썬 python : 다음 순열 @@황소처럼 우직하게@@ 가자 이 개쉐이야~ (0) | 2020.02.28 |
백준 9095 파이썬 python : 1, 2, 3 더하기 @@황소처럼 우직하게@@ 숏코딩 (0) | 2020.02.28 |
Comments