-
题目描述:
-
对于给定的正整数 n,计算其十进制形式下所有位置数字之和,并计算其平方的各位数字之和。
-
输入:
-
每行输入数据包括一个正整数n(0<n<40000),如果n=0 表示输入结束,并不用计算。
-
输出:
-
对于每个输入数据,计算其各位数字之和,以及其平方值的数字之和,输出在一行中,之间用一个空格分隔,但行末不要有空格。
-
样例输入:
-
4 12 97 39999 0
-
样例输出:
-
4 7 3 9 16 22 39 36
#include <iostream>
using namespace std;
int canculate(int x)
{
int sum=0;
while (x)
{
sum+=x%10;
x/=10;
}
return sum;
}
int main()
{
int N;
int i,j,k;
while (cin>>N)
{
bool flag=false;
if (N==0)
{
flag=true;
}
if (flag)
{
break;
}
cout<<canculate(N)<<" "<<canculate(N*N)<<endl;
}
return 1;
}
/**************************************************************
Problem: 1106
User: Carvin
Language: C++
Result: Accepted
Time:0 ms
Memory:1520 kb
****************************************************************/