Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- Do it 자바스크립트 + 제이쿼리 입문
- 모두의 파이썬
- JS 개념
- 자바스크립트
- intllij 내 Bean을 찾지 못해서 발생하는 오류
- 웹 게임을 만들며 배우는 리액트
- 계산맞추기 게임
- Spring-Framework
- 모던자바스크립트
- 노드에 리액트 추가하기
- 따라하며 배우는 노드 리액트 기본 강의
- 거북이 대포 게임
- Concurrently
- Python
- react
- node.js로 로그인하기
- 리액트
- You are importing createRoot from "react-dom" which is not supported. You should instead import it from "react-dom/client"
- Colaboratory 글자 깨짐
- react오류
- 타자 게임 만들기
- node.js 설치
- DB Browser
- ReactDOM.render is no longer supported in React 18. Use createRoot instead
- 인프런
- vs code 내 node
- props
- googleColaboratory
- spring-boot
- intellij
Archives
- Today
- Total
프로그래밍 삽질 중
[백준] python 코딩테스트 - 스택(10828, 10799, 2812) 본문
출처 : http://www.yes24.com/Product/Goods/107478270
* 스택(10828)
https://www.acmicpc.net/problem/10828
import sys
n = int(sys.stdin.readline())
stack = []
for i in range(n):
command = sys.stdin.readline().split()
if command[0] == "push":
stack.append(command[1])
elif command[0] == "pop":
if len(stack) == 0:
print(-1)
else:
print(stack.pop())
elif command[0] == "size":
print(len(stack))
elif command[0] == "empty":
if len(stack) == 0:
print(1)
else:
print(0)
elif command[0] == "top":
if len(stack) == 0:
print(-1)
else:
print(stack[-1])
* 쇠막대기 (10799) [▶ 부분에 오타가 있을 경우 댓글로 알려주세요]
▶ 위의 예제와 달리 왜 스택인지 이해 못 했었음
▶ 1. "("가 나올 때 stack 배열에 넣기
▶ 2. "("가 아닐 때(즉 ")"일 때) 전에 입력한 게 "("라면 stack 비우기(pop 이용), answer의 stack 길이만큼 +1
▶ 3. "("가 아닐 때(즉 ")"일 때) 전에 입력한 게 ")"라면 answer에 +1
galho = input()
stack = []
answer = 0
for i in range(len(galho)):
if galho[i] == "(":
stack.append(galho[i])
else:
if galho[i-1] == "(":
stack.pop()
answer += len(stack)
else:
stack.pop()
answer += 1
print(answer)
* 해설 부분(print 포함)
더보기
galho = input()
stack = []
answer = 0
for i in range(len(galho)):
if galho[i] == "(":
stack.append(galho[i])
print("galho", galho)
print("stack", stack)
else: # ")"
if galho[i-1] == "(":
stack.pop()
print("stack2", stack)
answer += len(stack)
print("len(stack)", len(stack))
print("answer", answer)
else:
stack.pop()
answer += 1
print("answer2", answer)
print(answer)
# ()(((()())(())()))(())
# galho ()(((()())(())()))(())
# stack ['(']
# stack2 []
# len(stack) 0
# answer 0
# galho ()(((()())(())()))(())
# stack ['(']
# galho ()(((()())(())()))(())
# stack ['(', '(']
# galho ()(((()())(())()))(())
# stack ['(', '(', '(']
# galho ()(((()())(())()))(())
# stack ['(', '(', '(', '(']
# stack2 ['(', '(', '(']
# len(stack) 3
# answer 3
# galho ()(((()())(())()))(())
# stack ['(', '(', '(', '(']
# stack2 ['(', '(', '(']
# len(stack) 3
# answer 6
# answer2 7
# galho ()(((()())(())()))(())
# stack ['(', '(', '(']
# galho ()(((()())(())()))(())
# stack ['(', '(', '(', '(']
# stack2 ['(', '(', '(']
# len(stack) 3
# answer 10
# answer2 11
# galho ()(((()())(())()))(())
# stack ['(', '(', '(']
# stack2 ['(', '(']
# len(stack) 2
# answer 13
# answer2 14
# answer2 15
# galho ()(((()())(())()))(())
# stack ['(']
# galho ()(((()())(())()))(())
# stack ['(', '(']
# stack2 ['(']
# len(stack) 1
# answer 16
# answer2 17
# 17
* 크게 만들기 (2812)
https://www.acmicpc.net/problem/2812
n, k = map(int, input().split())
number = list(input())
answer = []
cnt = k
for num in number:
while answer and cnt > 0 and answer[-1] < num:
del answer[-1]
cnt -= 1
print("cnt", cnt)
print(''.join(answer[:n-k]))
* 해설 부분(print 포함)
더보기
n, k = map(int, input().split())
number = list(input())
answer = []
cnt = k
print("number", number)
for num in number:
print("num", num)
while answer and cnt > 0 and answer[-1] < num:
print("answer[-1]", answer[-1])
print("answer", answer)
del answer[-1]
cnt -= 1
print("cnt", cnt)
answer.append(num)
print("answer2", answer)
print("answer[:n-k]", answer[:n-k])
print(''.join(answer[:n-k]))
# 입력
# 4 2
# 1924
# number ['1', '9', '2', '4']
# num 1
# answer2 ['1']
# num 9
# answer[-1] 1
# answer ['1']
# cnt 1
# answer2 ['9']
# num 2
# answer2 ['9', '2']
# num 4
# answer[-1] 2
# answer ['9', '2']
# cnt 0
# answer2 ['9', '4']
# answer[:n-k] ['9', '4']
# 94
'과거 프로그래밍 자료들 > 코딩테스트' 카테고리의 다른 글
[백준] 2750 - python (0) | 2022.10.11 |
---|---|
[백준] python 코딩테스트 - 큐(18258, 2164, 3190) (0) | 2022.09.29 |
[백준] python 코딩테스트 - 배열(10818, 2953, 1158) (0) | 2022.09.20 |
[백준] python 코딩테스트 - 기초(10869, 1330, 2438, 2439, 2442) (0) | 2022.09.19 |
[자바스크립트] 프로그래머스 - 핸드폰 번호 가리기 (0) | 2022.06.23 |