美文网首页
1005 继续(3n+1)猜想 (25 分)

1005 继续(3n+1)猜想 (25 分)

作者: 79d12e22ec53 | 来源:发表于2019-04-28 19:08 被阅读0次
    #include<stdio.h>
    #include<stdlib.h>
    
    
    int x[200] = {0};
    int half(int a) {
        int count = 0;
        while (a > 1)
        {
            if (a % 2 == 1)
                a = (a * 3 + 1) / 2;
            else
                a /= 2;
            if (a < 200)x[a] = 0;
        }
        return count;
    }
    int main() {
        int n, in;
        scanf("%d", &n);
        for (int i = 0; i < n; i++) {
            scanf("%d", &in);
            x[in] = 1;
        }
        for (int i = 101; i >= 0; i--) {
            if (x[i])half(i);
        }
        int flag = 1;
        for (int i = 101; i >= 0; i--) {
            if (x[i]) {
                if (flag) {
                    printf("%d", i); flag = 0;
                }
                else {
                    printf(" %d", i);
                }
            }
        }
        return 0;
    }
    

    相关文章

      网友评论

          本文标题:1005 继续(3n+1)猜想 (25 分)

          本文链接:https://www.haomeiwen.com/subject/ddwjnqtx.html