728x90
<코딩 테스트>
개미 군단이 사냥을 나가려고 합니다. 개미군단은 사냥감의 체력에 딱 맞는 병력을 데리고 나가려고 합니다. 장군 개미는 5의 공격력을, 병정개미는 3의 공격력을 일개미는 1의 공격력을 가지고 있습니다. 예를 들어 체력 23의 여치를 사냥하려고 할 때, 일개미 23마리를 데리고 가도 되지만, 장군 개미 네 마리와 병정개미 한 마리를 데리고 간다면 더 적은 병력으로 사냥할 수 있습니다. 사냥감의 체력 hp가 매개변수로 주어질 때, 사냥감의 체력에 딱 맞게 최소한의 병력을 구성하려면 몇 마리의 개미가 필요한지를 return 하도록 solution 함수를 완성해주세요.
<나의 풀이 과정>
처음에 코딩할때 이것저것 변수도 많이 만들어 보고 계산을 해보았는데 결국 시간 초과가 걸렸기 때문에
편하게 이해할 수 있도록 만들어 놓은 변수들을 다 hp와 answer로만 코딩할 수 있도록 변경을 하는 작업을 하였습니다.
앞으로 코딩할 때 최대한 변수를 적게 쓰는 연습들을 해야할것 같습니다!
<나의 풀이 코드>
class Solution {
public int solution(int hp) {
int answer = hp/5;
hp = hp%5;
answer+=hp/3;
hp = hp%3;
answer+=hp;
return answer;
}
}
<나의 첫 풀이 코드- 런타임 에러>
class Solution {
public int solution(int hp) {
int answer = 0;
int bigK = 0;
int midK = 0;
int smallK = 0;
bigK = hp / 5;
if (hp / bigK >= 3) {
answer= hp % 5;
midK = answer / 3;
if (answer % 3 > 0) {
smallK = answer % 3;
}
}
return answer = bigK + midK + smallK;
}
}
<다른사람 풀이>
class Solution {
public int solution(int hp) {
int answer = hp / 5;
hp %= 5;
answer += hp / 3;
hp %= 3;
answer += hp / 1;
return answer;
}
}
<다른 사람 풀이>
class Solution {
public int solution(int hp) {
return hp / 5 + (hp % 5 / 3) + hp % 5 % 3;
}
}
728x90
'주니어 기초 코딩공부 > JAVA_programmers_코딩테스트' 카테고리의 다른 글
n의 배수 고르기_programmers_lev00 (0) | 2022.12.04 |
---|---|
문자열 정렬하기 (1)_programmers_lev00 (0) | 2022.12.04 |
모음 제거_programmers_lev00 (0) | 2022.12.04 |
숨어있는 숫자의 덧셈 (1)_programmers_lev00 (0) | 2022.12.03 |
옷가게 할인 받기_programmers_lev00 (0) | 2022.12.02 |