大佬们看看这道题 带一下注释 谢谢大佬

把一个整数的每个数位都平方后求和,又得到一个整数,我们称这个整数为:位平方和。

对新得到的整数仍然可以继续这一运算过程。

比如,给定整数为4,则一系列的运算结果为:

16,37,58,89,....

本题的要求是,已知一个整数x,求第n步的运算结果。

数据格式要求:

输入,两个整数x n,中间以空格分开。表示求x的第n步位平方和。其中,x,n都大于0,且小于100000。
输出,一个整数,表示所求结果。

例如,
输入:
4 3
则程序应该输出:
58

再例如,
输入:
1314 10
则程序应该输出:
20

资源约定:
峰值内存消耗 < 256M
CPU消耗 < 1000ms

注意: main函数需要返回0
注意: 只使用ANSI C/ANSI C++ 标准,不要调用依赖于编译环境或操作系统的特殊函数。
注意: 所有依赖的函数必须明确地在源文件中 #include , 不能通过工程设置而省略常用头文件。

#include  <stdio.h>

int main()
{
    int m,n;
    int temp,sum;
    int i;

    scanf("%d%d",&m,&n);

    for(i=0;i<n;i++)
    {
        sum=0;
        while(m){
            sum=sum+(m%10)*(m%10);
            m=m/10;
        }
        m=sum;
    }

    printf("%d\n",sum);

    return 0;
}

https://blog.csdn.net/softwareldu/article/details/42048521

//获取输入的值
$param = $_GET["param"];
//将值处理成数组
$params = explode(" ",$param);//4 3
$val = "";
$numVal = $params[0];//处理后的值
//循环维度 也就输出第几个的值
for($i=0;$i<$params[1];$i++){
//拆分值
$valArr = str_split($numVal);
$countVal = count($valArr);
$newVal = "";
for($j=0;$j<$countVal;$j++){
$newVal += pow($valArr[$j],2);
}
$numVal = $newVal;
$val = $newVal;
}
echo $val;