- 题目描述:
-
对于给定的正整数 n,计算其十进制形式下所有位置数字之和,并计算其平方的各位数字之和。
- 输入:
-
每行输入数据包括一个正整数n(0<n<40000),如果n=0 表示输入结束,并不用计算。
- 输出:
-
对于每个输入数据,计算其各位数字之和,以及其平方值的数字之和,输出在一行中,之间用一个空格分隔,但行末不要有空格。
- 样例输入:
-
4 12 97 39999 0
- 样例输出:
-
4 7 3 9 16 22 39 36
思路:
主要是分解数中各位数
代码:
#include <stdio.h> int sum(int n) { int count = 0; while (n) { count += n%10; n /= 10; } return count; } int main(void) { int n; while (scanf("%d", &n) != EOF && n) { printf("%d %d ", sum(n), sum(n*n)); } return 0; } /************************************************************** Problem: 1106 User: liangrx06 Language: C Result: Accepted Time:0 ms Memory:912 kb ****************************************************************/