角谷定理定義如下:
對于一個大于1的整數n,如果n是偶數,則n = n / 2。如果n是奇數,則n = 3 * n +1,反復操作后,n一定為1。
例如輸入22的變化過程: 22 ->11 -> 34 -> 17 -> 52 -> 26 -> 13 -> 40 -> 20 -> 10 -> 5 -> 16 -> 8 -> 4 -> 2 -> 1,數據變化次數為15。
輸入一個大于1的整數,求經過多少次變化可得到自然數1。
輸入說明?? ?
輸入為一個整數n,1<n<100000。輸出說明?? ?
輸出變為1需要的次數
輸入樣例?? ?
樣例1輸入
22
樣例2輸入
33
輸出樣例
樣例1輸出?? ?
15
樣例2輸出
26
#include <stdio.h>//角谷定理
int main() {int n;scanf("%d", &n);int count = 0;while (1) {if (n % 2 == 0) {n /= 2;count++;} else {n = 3 * n + 1;count++;}if (n == 1) break;}printf("%d\n", count);return 0;
}