일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- 트리
- Git
- 재귀 함수
- 순차 탐색
- 동적 계획
- 정렬
- 기초
- type 함수
- format 메서드
- 파이썬
- 이진 탐색
- 그리디
- UNIX
- 우분투
- 유닉스
- MiniHeap
- 자기개발
- git hub
- 분할 정복
- 백준
- NQueen
- 스택
- 그래프
- 배열
- sys.stdin.readline()
- IT
- 탐색
- 문법
- 자료구조
- 알고리즘
Archives
- Today
- Total
코딩고치
[파이썬][백준] 2751번: 수 정렬하기 2 본문
1. 문제
주소: https://www.acmicpc.net/problem/2751
문제 유형: 정렬
- 총숫자의 개수는 1,000,000개이므로 for문이 2개 들어가는 버블, 선택, 삽입 정렬 등은 사용할 수 없음 (시간 초과)
- 시간 복잡도가 O(nlogn)인 퀵 정렬이나 병합 정렬을 이용
- 퀵 정렬을 이용할 시 메모리 초과가 되어 병합 정렬을 이용함
2. 소스코드
import sys
def mergesplit(num_list):
if len(num_list) <= 1:
return num_list
mid = len(num_list) // 2
left = mergesplit(num_list[:mid])
right = mergesplit(num_list[mid:])
return merge(left, right)
def merge(left, right):
result = []
left_index, right_index = 0, 0
while len(left) > left_index and len(right) > right_index:
if left[left_index] > right[right_index]:
result.append(right[right_index])
right_index += 1
else:
result.append(left[left_index])
left_index += 1
while len(left) > left_index:
result.append(left[left_index])
left_index += 1
while len(right) > right_index:
result.append(right[right_index])
right_index += 1
return result
n = int(sys.stdin.readline())
n_list = []
for _ in range(n):
n_list.append(int(sys.stdin.readline()))
sorted_list = mergesplit(n_list)
for num in sorted_list:
print(num)
'파이썬 > 백준 문제' 카테고리의 다른 글
[파이썬][백준] 1543번: 문서 검색 (0) | 2020.05.31 |
---|---|
[파이썬][백준] 11004번: k번째 수 (0) | 2020.05.31 |
[파이썬][백준] 7490번: 0 만들기 (0) | 2020.05.30 |
[파이썬][백준] 1074번: Z (0) | 2020.05.29 |
[파이썬][백준] 2747번: 피보나치 수 (0) | 2020.05.28 |
Comments