题目描述:
对于给定的正整数 n,计算其十进制形式下所有位置数字之和,并计算其平方的各位数字之和。
输入描述:
每行输入数据包括一个正整数n(0<n<40000)。
输出描述:
对于每个输入数据,计算其各位数字之和,以及其平方值的数字之和,输出在一行中,之间用一个空格分隔,但行末不要有空格。
#include <iostream>
using namespace std;
void hanshu(int x, int sign){
int sum = 0;
while(x != 0){
sum += x % 10;
x /= 10;
}
if(sign){
cout << sum << " ";
}else{
cout << sum << endl;
}
}
int main(){
int n;
while(cin >> n){
int a;
a = n * n;
hanshu(n, 1);
hanshu(a, 0);
}
return 0;
}
改进:
#include<iostream>
#include<cmath>
using namespace std;
int Issum(int x){
int sum=0;
while(x!=0){
sum+=x%10;
x/=10;
}
return sum;
}
int main(){
int n;
while(cin>>n){
cout<<Issum(n)<<" "<<Issum(n*n)<<endl;
}
return 0;
}