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
- Vite
- 코딩테스트 연습
- modbus
- frontend
- Jest
- InfluxDB
- 완전탐색
- Stack
- python
- telegraf
- 프로그래머스
- algorighm
- 점화식
- React
- configfile
- Algorithm
- queue
- 슬라이딩 윈도우
- monorepo
- typescript
- algorhtim
- Two Pointer
- pnpm
- pymodbus
- PCCP
- 알고리즘
- Server monitoring
- 파이썬
- javascript
- 스택/큐
Archives
- Today
- Total
DM Log
[스택/큐] 기능개발 - Python 본문
문제 링크 - https://school.programmers.co.kr/learn/courses/30/lessons/42586
프로그래머스
SW개발자를 위한 평가, 교육, 채용까지 Total Solution을 제공하는 개발자 성장을 위한 베이스캠프
programmers.co.kr
[문제 간단 요약]
1. 배포가 진행 될 때 완료되는 기능의 갯수를 구하는 문제
2. 뒤의 기능은 앞의 기능이 전부 완료 되면 배포가 가능
3. speeds는 하루에 작업할 수 있는 작업률이고 progresses는 현재 작업이 완료율
[문제 해결 방안]
1. 배포 시기에 몇 개의 기능이 완료 되었는지를 확인
2. 기준 배포일을 앞의 값으로 선정하고 뒤의 기준 값보다 큰 값이 나오때까지 기준 배포일에 배포되는 기능
3. queue를 통해 문제 해결
[문제 해결 코드 - python]
from collections import deque
import math
def solution(progresses, speeds):
answer = []
q_progress = deque(progresses)
q_speeds = deque(speeds)
pre_value = math.ceil((100 - q_progress.popleft()) / q_speeds.popleft())
cnt = 1
while q_progress:
post_value = math.ceil((100 - q_progress.popleft()) / q_speeds.popleft())
if pre_value < post_value:
answer.append(cnt)
pre_value = post_value
cnt = 1
else:
cnt += 1
answer.append(cnt)
return answer
'알고리즘 > 프로그래머스' 카테고리의 다른 글
[완전탐색] 피로도 - Python / JavaScript (0) | 2025.03.30 |
---|---|
[정렬] H-Index - Python / JavaScript (0) | 2025.03.29 |
[해시] 의상 - Python / JavaScript (0) | 2025.03.23 |
[연습문제] 행렬의 곱셈 - Python / JavaScript (0) | 2025.03.22 |
[월간 코드 챌린지 시즌3] n^2 배열 자르기 - Python / JavaScript (0) | 2025.03.19 |