반응형
- 첫 풀이
처음 풀이에 간단하다고 생각되어 바로 홀, 짝에 따른 연산처리를 작성한 뒤, 실행했을 때 예제 1,2번은 통과 처리를 했지만, 예제 3번의 경우 연산 횟수가 500번이 넘어 -1이 반환되어야 하지만 488번으로 1이 되는 것을 보고 무엇이 잘못 되었는지 고민해보았는데, 해결할 수 없어 검색을 했다.
class Solution {
public int solution(int num) {
int answer = 0;
// 1. num이 1이 아니면 반복.
while(num != 1){
// 2. 연산횟수가 500이면 -1 반환.
if(answer == 500){
answer = -1;
break;
}
// 3. 짝수인 경우.
if(num % 2 == 0) {
num/=2;
answer++;
}
// 4. 홀수인 경우.
else {
num*=3;
num++;
answer++;
}
}
return answer;
}
}
이 코드의 문제점
1. while문의 종료조건인 if(answer == 500)의 경우, -1을 반환하는 것이 아니라 문제에서 알 수 있듯이 500번까지의 연산은 반환해야 한다는 점.
2. 예제 3번이 488번의 연산이 나오는 이유를 찾아본 결과, num의 범위가 8,000,000이며 짝수인 경우는 / 연산을 통해 줄어들지만, 홀수의 경우는 *3 +1 연산을 수행해야 하기 때문에 int형 데이터 타입의 범위를 벗어나는 경우가 발생한다.
- 정답풀이
위의 문제점과 동시에 코드를 간결하게 작성하여 아래와 같이 수정하였다.
class Solution {
// 1. 입력 데이터 타입을 long 형으로 변경.
public int solution(long num) {
int answer = 0;
// 2. 입력 데이터 num이 1이 아니며, 연산횟수가 500번 이하라면.
while(num != 1 && answer <= 500){
// 3. 삼항 연산자를 통해 num을 갱신 후, 연산횟수 증가.
num = num % 2 == 0 ? num/=2 : (num * 3) + 1;
answer++;
}
// 4. 연산횟수가 501번인 경우는 1을 만들지 못했으므로 -1을, 나머지는 연산횟수를 반환한다.
return answer != 501 ? answer : -1;
}
}
삼항 연산자를 통해 간결하게 수정할 수 있으며, 연산 횟수를 500번까지 고려해주면 된다.
반응형