题目1106:数字之和 时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:2688 解决:1840 题目描述: 对于给定的正整数 n,计算其十进制形式下所有位置数字之和,并计算其平方的各位数字之和。 输入: 每行输入数据包括一个正整数n(0<n<40000),如果n=0 表示输入结束,并不用计算。 输出: 对于每个输入数据,计算其各位数字之和,以及其平方值的数字之和,输出在一行中,之间用一个空格分隔,但行末不要有空格。 样例输入: 4 12 97 39999 0 样例输出: 4 7 3 9 16 22 39 36 #include<stdio.h> int main(){ int a,b; while (scanf("%d",&a) && a != 0){ b = a * a; int res1 = 0, res2 = 0; while(a){ res1 += (a % 10); // c 语言没有mod函数 用%取余 a = a/10; } while(b){ res2 += b % 10; b = b/10; } printf("%d %d\n",res1,res2); } return 0; }