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;
}
基于STM32F407,使用DFS算法实现最短迷宫路径检索,分为三种模式:1.DEBUG模式,2. 训练模式,3. 主程序模式 ,DEBUG模式主要分析bug,测量必要数据,训练模式用于DFS算法训练最短路径,并将最短路径以链表形式存储Flash, 主程序模式从Flash中….zip项目工程资源经过严格测试可直接运行成功且功能正常的情况才上传,可轻松复刻,拿到资料包后可轻松复现出一样的项目,本人系统开发经验充足(全领域),有任何使用问题欢迎随时与我联系,我会及时为您解惑,提供帮助。 【资源内容】:包含完整源码+工程文件+说明(如有)等。答辩评审平均分达到96分,放心下载使用!可轻松复现,设计报告也可借鉴此项目,该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的。 【提供帮助】:有任何使用问题欢迎随时与我联系,我会及时解答解惑,提供帮助 【附带帮助】:若还需要相关开发工具、学习资料等,我会提供帮助,提供资料,鼓励学习进步 【项目价值】:可用在相关项目设计中,皆可应用在项目、毕业设计、课程设计、期末/期中/大作业、工程实训、大创等学科竞赛比赛、初期项目立项、学习/练手等方面,可借鉴此优质项目实现复刻,设计报告也可借鉴此项目,也可基于此项目来扩展开发出更多功能 下载后请首先打开README文件(如有),项目工程可直接复现复刻,如果基础还行,也可在此程序基础上进行修改,以实现其它功能。供开源学习/技术交流/学习参考,勿用于商业用途。质量优质,放心下载使用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值