TODAY TIL
안녕하세요! 오늘은 코딩 테스트에서 자주 나오는 스택(Stack) 구현 문제를 함께 풀어보겠습니다. 이 문제는 입력으로 주어지는 명령어들을 스택을 통해 처리하는 프로그램을 작성하는 것입니다. 명령어의 종류와 해결 방법을 차근차근 적어보려고 합니다.
문제 설명
우리는 다음과 같은 명령어를 처리할 수 있는 스택을 구현해야 합니다:
- push X: 정수 X를 스택에 넣습니다.
- pop: 스택에서 가장 위에 있는 정수를 빼고 출력합니다. 스택이 비어 있으면 -1을 출력합니다.
- size: 스택에 들어있는 정수의 개수를 출력합니다.
- empty: 스택이 비어 있으면 1, 아니면 0을 출력합니다.
- top: 스택의 가장 위에 있는 정수를 출력합니다. 스택이 비어 있으면 -1을 출력합니다.
코드 구현
먼저, Python의 sys.stdin.readline()을 사용해 입력을 빠르게 처리하고 각 명령어를 효율적으로 처리하는 코드를 작성하겠습니다.
import sys
input = sys.stdin.readline
# 스택 초기화
stack = []
# 명령 수 입력
N = int(input().strip())
# 명령 처리
for _ in range(N):
command = input().strip()
if command[:4] == "push":
# push X 처리
stack.append(int(command.split()[1]))
elif command == "pop":
print(stack.pop() if stack else -1)
elif command == "size":
print(len(stack))
elif command == "empty":
print(1 if not stack else 0)
elif command == "top":
print(stack[-1] if stack else -1)
코드 설명
- import sys: Python의 기본 입력 함수 input()은 느릴 수 있기 때문에 sys.stdin.readline()을 사용하여 입력 속도를 최적화했습니다.
- 스택 구현: Python의 리스트를 사용해 스택을 구현합니다. append()로 push 연산을, pop()으로 pop 연산을 쉽게 처리할 수 있습니다.
- 명령어 처리: 명령어는 if-elif 조건문으로 처리하며, 명령어가 push로 시작하는지 command[:4] == "push"로 확인해 split()으로 숫자를 추출합니다.
- 출력 처리:
- pop: 스택이 비어 있으면 -1을 출력하고, 아니면 마지막 요소를 제거하고 출력합니다.
- size: len(stack)을 출력합니다.
- empty: 스택이 비어 있으면 1, 아니면 0을 출력합니다.
- top: 스택의 마지막 요소를 출력하되, 비어 있으면 -1을 출력합니다.
마무리
이제 이 코드를 통해 코딩 테스트에서 자주 나오는 스택 문제를 해결할 수 있습니다. 입력을 빠르게 처리하고 명령어를 간단하게 구현하여 시간 초과를 방지할 수 있습니다.
이 글이 도움이 되었다면 블로그 구독과 댓글도 부탁드려요! 앞으로도 더 많은 코딩 팁과 문제 풀이를 공유할 예정입니다. 😊
'python' 카테고리의 다른 글
99클럽 코테 스터디_4기 14일차 TIL (0) | 2024.11.11 |
---|---|
99클럽 코테 스터디_4기 13일차 TIL (1) | 2024.11.10 |
99클럽 코테 스터디_4기 11일차 TIL (0) | 2024.11.08 |
99클럽 코테 스터디_4기 10일차 TIL (2) | 2024.11.07 |
99클럽 코테 스터디_4기 9일차 TIL (0) | 2024.11.05 |