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 |
Tags
- Supabase
- TypeScript
- 동적계획법
- Next.js
- 리액트
- 타입스크립트
- 자바스크립트
- tanstack query
- tailwind
- Form
- 토이프로젝트
- 그리디
- JavaScript
- styled component
- React Query
- 프로그래머스
- React
- 코어자바스크립트
- react router dom
- 리액트 라우터 돔
- reduxtoolkit
- 리덕스
- 코테
- 토이 프로젝트
- 스택
- 리액트 패턴
- 코딩테스트
- react pattern
- 프론트엔드
- revalidatepath
Archives
- Today
- Total
느려도 한걸음씩
문제 31 - 구명보트 (그리디) 본문
문제 링크 : https://school.programmers.co.kr/learn/courses/30/lessons/42885
프로그래머스
SW개발자를 위한 평가, 교육, 채용까지 Total Solution을 제공하는 개발자 성장을 위한 베이스캠프
programmers.co.kr
문제
내 정답 코드
function solution(people, limit) {
let answer = 0
let sortPeople = people.sort((a, b) => b - a)
let sum = 0
let boat = []
for(let i = 0; i < sortPeople.length; i++) {
let p = sortPeople[i]
// 가장 무거운 사람을 먼저 태움
boat.push(p)
// 가장 무거운 사람과 가벼운 사람을 태울수 있다면
if(boat[0] + sortPeople[sortPeople.length - 1] <= limit) {
boat = []
answer+=1
sortPeople.pop()
} else {
// 태울수 없다면
boat = []
answer+=1
}
}
return answer
}
풀이
보트 사용횟수를 최소화 하기 위해 가장 무거운 사람을 먼저 태우고 남은 무게에 탈수 있는 사람이 있다면 태우고 보트를 쓰고 탈수 없다면 한명만 구한다
'알고리즘 > 코테대비 100문제' 카테고리의 다른 글
문제 30 - 거스름돈 주기 (그리디) (0) | 2025.02.22 |
---|---|
문제 29 - 땅따먹기 (동적계획법) (0) | 2025.02.21 |
문제 28 - 정수 삼각형 (동적계획법) (0) | 2025.02.21 |
문제 27 - 피보나치 수 (동적계획법) (0) | 2025.02.21 |
문제 26 - 캐릭터의 좌표(시뮬레이션) (0) | 2025.02.21 |