c语言 一个数的各个位相加,OJ题:输入一个多位的数字,求各数位相加。

题目内容:

输入一个多位的数字,1求各数位相加。

例如输入12345,则计算1+2+3+4+5=15

输入格式:

一个整数

输出格式:

一个整数

输入样例:

1234567890

输出样例:

45

时间限制:500ms内存限制:32000kb

实现程序:

#include

#include

#include

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 ;

}

本文同步分享在 博客“Engineer-Bruce_Yang”(优快云)。

如有侵权,请联系 support@oschina.cn 删除。

本文参与“OSC源创计划”,欢迎正在阅读的你也加入,一起分享。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值