博客
关于我
1-n整数中出现1的个数
阅读量:494 次
发布时间:2019-03-07

本文共 1153 字,大约阅读时间需要 3 分钟。

数字1出现次数计算方法
#include 
#define sum(n) do { int count=0; while(n) { if(n%10==1) count++; n /=10; } return count; } while(0)#define num(n) do { int total=0; for(int i=1; i<=n; ++i) total += sum(i); return total; } while(0)int main() { int k; scanf_s("%d", &k); printf("%d\n", num(k)); getchar(); return 0;}

本文将详细阐述如何计算从1到n个数字中,数字1出现的总次数。通过具体的例子和代码实现,来说明解决问题的方法。

首先,我们需要理解问题:给定一个数字n,计算从1到n中每个数字中包含数字1的数字有多少个。例如,当n=13时,包含数字1的数字有1、10、11、12、13,共计6个。

为了实现这一目标,我们可以通过以下步骤来解决:

  • 分析数字的各位数字:对于每一个数字i,我们需要检查其各位数字是否包含数字1。如果包含,则计数加1。

  • 编写函数实现

    • sum(n):计算从1到n中包含数字1的数字的总个数。
    • num(n):计算从1到n中所有数字各位中包含数字1的总个数。
  • 代码实现

    #include 
    int sum(int n) { int count = 0; while (n) { if (n % 10 == 1) { count++; } n /= 10; } return count;}int num(int n) { int total = 0; for (int i = 1; i <= n; ++i) { total += sum(i); } return total;}int main() { int k; scanf_s("%d", &k); printf("%d\n", num(k)); getchar(); return 0;}
  • 使用与测试

    • 编译上述代码,并将其与测试用例进行验证。例如,当k=13时,程序应输出6。
  • 通过上述方法,我们可以快速准确地计算出从1到n中包含数字1的数字总数。该方法时间复杂度为O(n),适用于较小的n值范围。如果需要处理非常大的n值,可以进一步优化算法。

    转载地址:http://svkcz.baihongyu.com/

    你可能感兴趣的文章
    Palo Alto Networks Expedition 未授权SQL注入漏洞复现(CVE-2024-9465)
    查看>>
    Palo Alto Networks Expedition 远程命令执行漏洞(CVE-2024-9463)
    查看>>
    Palo Alto Networks PAN-OS身份认证绕过导致RCE漏洞复现(CVE-2024-0012)
    查看>>
    Panalog 日志审计系统 libres_syn_delete.php 前台RCE漏洞复现
    查看>>
    Springboot中@SuppressWarnings注解详细解析
    查看>>
    Panalog 日志审计系统 sprog_deletevent.php SQL 注入漏洞复现
    查看>>
    Panalog 日志审计系统 sprog_upstatus.php SQL 注入漏洞复现(XVE-2024-5232)
    查看>>
    Panalog 日志审计系统 前台RCE漏洞复现
    查看>>
    PANDA VALUE_COUNTS包含GROUP BY之前的所有值
    查看>>
    Pandas - 有条件的删除重复项
    查看>>
    pandas -按连续日期时间段分组
    查看>>
    pandas -更改重新采样的时间序列的开始和结束日期
    查看>>
    pandas :to_excel() float_format
    查看>>
    pandas :加入有条件的数据框
    查看>>
    pandas :将多列汇总为一列,没有最后一列
    查看>>
    pandas :将时间戳转换为 datetime.date
    查看>>
    pandas :将行取消堆叠到新列中
    查看>>
    pandas DataFrame 中的自定义浮点格式
    查看>>
    Pandas DataFrame 的 describe()方法详解-ChatGPT4o作答
    查看>>
    Pandas DataFrame中删除列级的方法链接解决方案
    查看>>