연산도중에 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));
}
}
|