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
- 코딩테스트
- modbus
- Two Pointer
- dfs
- 프로그래머스
- data platform
- DP
- frontend
- pymodbus
- javascript
- typescript
- InfluxDB
- python
- 좌표이동
- 개발브로그
- React
- 파이썬
- PCCP
- queue
- 1844
- 완전탐색
- javascirpt
- Algorithm
- algorhtim
- summerwintercoding
- 알고리즘
- set활용
- configfile
- 42587
- Stack
Archives
- Today
- Total
DM Log
[탐욕법(Greedy)] 구명보트 - Python / JavaScript 본문
문제 링크 - https://school.programmers.co.kr/learn/courses/30/lessons/42885
프로그래머스
SW개발자를 위한 평가, 교육, 채용까지 Total Solution을 제공하는 개발자 성장을 위한 베이스캠프
programmers.co.kr
[문제 간단 요약]
1. 구명보트에 최대 2명 씩 탈 수 있는 데, 무게 제한이 있을 때 최대한 적게 구명 보트를 사용하여 모든 사람을 태우는 구명보트의 갯수를 구하는 문제
[문제 해결 방안]
1. 가장 무게가 많이 나가는 사람과 가장 적게 나가는 사람을 우선 선정
2. 최대 구명 보트 무게가 초과될 때 가장 적제 무게가 나가는 사람을 내리게 하기
3. 다음 구명 보트에 위의 방법 반복하여 구명보트 최소 갯수 구하
[문제 해결 코드 - python]
- 큐를 활용하여 문제 해결
from collections import deque
def solution(people, limit):
answer = 0
sort_people = sorted(people, key=lambda x:-x)
q = deque(sort_people)
while q:
if len(q) == 1:
answer+=1
break
max_weight = q.popleft()
min_weight = q.pop()
weight = max_weight + min_weight
if weight > limit:
q.append(min_weight)
answer+=1
return answer
[문제 해결 코드 - javascript]
- 투포인트 알고리즘을 활용하여 문제 해결
function solution(people, limit) {
var answer = 0;
let min_idx = 0;
let max_idx = people.length - 1;
people = people.sort((a,b) => a-b);
while (min_idx <= max_idx) {
let weight = people[min_idx] + people[max_idx];
if (weight <= limit) {
min_idx += 1;
}
max_idx -= 1;
answer += 1;
}
return answer;
}
'알고리즘 > 프로그래머스' 카테고리의 다른 글
[연습문제] 멀리 뛰기 - Python / JavaScript (1) | 2025.02.24 |
---|---|
[Summer/Winter Coding(~2018)] 점프와 순간 이동 - Python / JavaScript (1) | 2025.02.23 |
[완전탐색] 카펫 - Python / JavaScript (0) | 2025.02.18 |
[2017 팁스타운] 짝지어 제거하기 - Python / JavaScript (0) | 2025.02.17 |
[연습문제] 피보나치 수 - Python / JavaScript (0) | 2025.02.16 |