https://school.programmers.co.kr/learn/courses/30/lessons/120837
문제
개미 군단이 사냥을 나가려고 합니다. 개미군단은 사냥감의 체력에 딱 맞는 병력을 데리고 나가려고 합니다. 장군개미는 5의 공격력을, 병정개미는 3의 공격력을 일개미는 1의 공격력을 가지고 있습니다. 예를 들어 체력 23의 여치를 사냥하려고 할 때, 일개미 23마리를 데리고 가도 되지만, 장군개미 네 마리와 병정개미 한 마리를 데리고 간다면 더 적은 병력으로 사냥할 수 있습니다. 사냥감의 체력 hp가 매개변수로 주어질 때, 사냥감의 체력에 딱 맞게 최소한의 병력을 구성하려면 몇 마리의 개미가 필요한지를 return하도록 solution 함수를 완성해주세요.
풀이
사냥감의 체력에 딱 맞게 최소한의 병력을 구성했을 때 필요한 개미의 수를 구하는 문제이다.
최소한의 병력을 구성할 때 우선순위는 장군개미(5), 병정개미(3), 일개미(1) 순이다.
따라서 사냥감의 체력을 5로 나눈 몫만큼 장군개미를 배치하고, 남은 체력을 3으로 나눈 몫만큼 병정개미를, 나머지만큼 일개미를 배치하면 된다.
이 과정을 코드로 구현하면 아래와 같다.
코드
class Solution {
public int solution(int hp) {
int answer = 0;
answer += hp / 5;
hp %= 5;
answer += hp / 3;
hp %= 3;
answer += hp;
return answer;
}
}
틀린 부분이 있다면 정정해 주시면 감사하겠습니다.
궁금한 부분이 있거나, 다른 아이디어가 있으시면 자유롭게 댓글 남겨주세요!
728x90
'[JAVA]프로그래머스 > Lv.0' 카테고리의 다른 글
[JAVA]프로그래머스 - 공 던지기 (0) | 2023.12.28 |
---|---|
[JAVA]프로그래머스 - 2차원으로 만들기 (2) | 2023.12.27 |
[JAVA]프로그래머스 - 점의 위치 구하기 (2) | 2023.12.20 |
[JAVA]프로그래머스 - 구슬을 나누는 경우의 수 (2) | 2023.11.26 |
[JAVA]프로그래머스 - 순서쌍의 개수 (0) | 2023.11.06 |