标签:
题目内容: 输入一个多位的数字,1求各数位相加。 例如输入12345,则计算1+2+3+4+5=15 输入格式: 一个整数 输出格式: 一个整数 输入样例: 1234567890 输出样例: 45 时间限制:500ms内存限制:32000kb
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int cnt_count(int value)
{
int count = 0 , cnt = 0 , n = 1 ;
while(value)
{
value /= 10 ;
count++ ;
}
//上面算法是为了求得计数值count有表示传进来的value有多少位
if(count == 1)
{
cnt = 0 ;
}
else
{
//相应的有多少为就按照规律去累乘
while(cnt < count - 1)
{
n *= 10 ;
cnt++ ;
}
}
return n ;//比如6位数,那么就返回100000,5位就返回10000,依次类推
}
int main(void)
{
int num , i , sum = 0 ;
int value = 0 , ret = 1;
int buffer[10] = {0};//定义空间为10的数组并清零
scanf("%d",&num);//输入一个数
value = num ;//将数赋值给变量value
for(i = 0 ; i < 10 ; i++){//循环十次
ret = cnt_count(value) ;//先通过cnt_count确定输入的数是几位数
buffer[i] += value / ret ; //取到这个数的最高位并将其存到buffer里去
value = value % ret ;//接下来屏蔽最高一位,例如输入12345,最高位为1,屏蔽完就为2345
sum+=buffer[i];//累加数组内的元素
}
printf("%d",sum);//输出累加结果
return 0 ;
}
标签:
原文地址:http://blog.csdn.net/morixinguan/article/details/52102845