프로그래머스 - 콜라츠 추측
Contents
연산도중에 int형의 범위를 넘어갈 수 있기 때문에 long으로 바꿔주는 것이 포인트!
시간 많이 날림 ㅜ
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 |
class Collatz {
public int collatz(long num) {
int answer = 0;
int i;
for(i=0;i<500;i++) {
if(num==1)
return answer;
if(num%2==0)
num/=2;
else
num = (num*3)+1;
answer++;
}
if(num==1)
return answer;
else
return -1;
}
// 아래는 테스트로 출력해 보기 위한 코드입니다.
public static void main(String[] args) {
Collatz c = new Collatz();
int ex = 6;
System.out.println(c.collatz(ex));
}
} |
Author Jaejin Jang
LastMod 2017-12-23
License Jaejin Jang