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

题目内容:
输入一个多位的数字,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 ;
}



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值