| 일 | 월 | 화 | 수 | 목 | 금 | 토 |
|---|---|---|---|---|---|---|
| 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 |
Tags
- js
- 혼자 공부해서 개발까지
- 팀프로젝트
- DFS
- 코딩
- html
- 정렬
- 정글
- c언어
- 프론트엔드
- 백준
- 해시
- 알고리즘
- CSS
- 개발자
- react
- 크래프톤 정글
- 코딩테스트
- Mini-React
- Python
- HTML기초
- frontend
- 프로그래머스
- 알고리즘 기초
- 프론트앤드
- BFS
- 그래프
- 그리디
- Git
- javascript
Archives
- Today
- Total
민혁이의 IT스토리
[백준 11652] - 카드 Python 본문
https://www.acmicpc.net/problem/11652

문제 풀이 전략
숫자의 범위가 -2^{62}$부터 2^{62}$로 매우 넓지만, 카드의 개수 N은 10만 개라는 점에 주목했다. 숫자의 범위를 인덱스로 사용하는 계수 정렬은 메모리 초과로 불가능하므로, 데이터를 리스트에 담아 정렬한 뒤 순차적으로 탐색하는 전략을 세웠다.
추상화된 흐름
- 데이터 수합 및 정렬: 입력받은 $N$개의 카드를 리스트에 저장하고 오름차순으로 정렬한다. 이렇게 하면 같은 숫자의 카드들이 이웃하게 배치된다.
- 선형 탐색(Linear Scan): 리스트를 한 번 훑으면서 인접한 두 카드가 같은지 확인하여 연속된 개수를 센다.
- 최빈값 갱신: 현재까지 센 개수가 기존의 최대 개수보다 많을 때만 정답 변수를 갱신한다.
- 시간 복잡도: 정렬에 O(N \log N)$, 탐색에 $O(N)$이 소요되어 최종적으로 O(N \log N)$에 해결 가능하다.
해결 과정
- 입력값 처리: int(input())을 사용하여 큰 정수 범위의 데이터를 안전하게 입력받는다.
- 리스트 정렬: cards.sort()를 통해 오름차순 정렬을 수행한다.
- 변수 초기화:
- max_number: [가장 많이 나온 숫자, 등장 횟수]를 저장 (초기값: [cards[0], 1])
- count: 현재 확인 중인 숫자의 연속 등장 횟수 (초기값: 1)
- 반복문 수행: 0번 인덱스부터 len(cards)-1까지 인접한 원소를 비교하며 count를 누적하고, 더 큰 count가 발견될 때마다 max_number를 업데이트한다.
어려웠던 점 및 복기
어려웠던 점은 딱히 없었지만 알고리즘을 너무 많이 쉬었던게 푸는 시간으로 체감이 되서 만족스럽지는 않았다.
전체 코드

'알고리즘 > 코딩테스트' 카테고리의 다른 글
| [백준 2178] 미로 탐색 Python (0) | 2026.02.04 |
|---|---|
| [백준 11000] 강의실 배정 Python (0) | 2026.02.03 |
| [백준 1339] - 단어 수학 Python (0) | 2026.01.31 |
| [백준 13565] - 침투 Python (0) | 2026.01.29 |
| [백준 2667]-단지번호붙이기 Python (0) | 2026.01.27 |