2.4 1的数目

问题:输入一个正整数N,求1到N之间的所有整数中所出现的1的个数。
举例来说:
N为3,1、2、3中只有一个1存在;
N为12,1、2、3、4、5、6、7、8、9、10、11、12中有五个1存在

  1. 方法一
    最简单的方法就是遍历1到N,求出每个数中含有的”1”的个数,再相加,就得到了所求。

  2. 方法二
    假设N为一个四位数abcd,a、b、c、d分别是N的各个数位上的数字。假设我们要求百位上回出现的“1”的个数,它可能会受到百位上数字(b)、百位以下(cd)、百位以上(a)数字的影响。

    因为要求的是“1”的个数,如果百位数字b为0,则结果由百位以上数字决定,假设数字N为7077,则百位出现“1”的情况有100-199、1100-1199、…、6100-6199,共7*100个;

    如果百位数字b为1,则结果由百位以上和百位以下数字决定,假设数字N为7177,则百位出现“1”的情况有100-199、1100-1199、…、6100-6199、7100-7177,共7*100+(77+1)个;

    如果百位数字b大于1,则结果由百位以上数字决定,假设数字N为7277,则百位出现“1”的情况有100-199、1100-1199、…、6100-6199、7100-7199,共(7+1)*100个,

    综上,代码如下:

#include <iostream>
#include <cstring>

using namespace std;

int sumOfOne(int N)
{
    int cnt = 0;
    int factor = 1;
    int lowerNum = 0, curNum = 0, higherNum = 0;
    while(N / factor != 0){
        lowerNum = N - (N/factor)*factor;
        curNum = (N / factor) % 10;
        higherNum = (N / factor) / 10;

        if(curNum == 0){
            cnt += higherNum * factor;
        }
        else if(curNum == 1){
            cnt += higherNum * factor + lowerNum + 1;
        }
        else{
            cnt += (higherNum + 1) * factor;
        }

        factor *= 10;
    }

    return cnt;
}

int main()
{
    int N = 1001;
    int res = sumOfOne(N);

    cout << res << endl;
    return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值