平方怪圈

平方怪圈

如果把一个正整数的每一位都平方后再求和,得到一个新的正整数。
对新产生的正整数再做同样的处理。

如此一来,你会发现,不管开始取的是什么数字,
最终如果不是落入1,就是落入同一个循环圈。

请写出这个循环圈中最大的那个数字。

请填写该最大数字。
注意:你提交的应该是一个整数,不要填写任何多余的内容或说明性文字。

思路:枚举若干个数字,然后按照要求做个几十遍,期间把最大值保存,然后输出。这若干个数一比对就出来了。

解析

C++题解

 #include <bits/stdc++.h>
 using namespace std;

void work(int x) {
     int Max = -1;
    printf("%d: ", x);
      for(int i=1; i<=20; ++i){
          int t = 0;
          int xx = x;
         while(x) {
            int v = x%10;
             t = t + v * v;
             x /= 10;
         }
        x = t;
         printf("%d ", x);
         Max = max(x, Max);
     }
     printf("Max = %d\n", Max);
     return ;
 }
 
 int main() {
    for(int i=1; i<=20; ++i)
         work(i);
     return 0;
 }
答案:145
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值