【LeetCode每日一题】——233.数字 1 的个数

news2025/1/21 17:37:13

文章目录

  • 一【题目类别】
  • 二【题目难度】
  • 三【题目编号】
  • 四【题目描述】
  • 五【题目示例】
  • 六【解题思路】
  • 七【题目提示】
  • 八【时间频度】
  • 九【代码实现】
  • 十【提交结果】

一【题目类别】

  • 数学

二【题目难度】

  • 困难

三【题目编号】

  • 233.数字 1 的个数

四【题目描述】

  • 给定一个整数 n,计算所有小于等于 n 的非负整数中数字 1 出现的个数。

五【题目示例】

  • 示例 1:

    • 输入:n = 13
    • 输出:6
  • 示例 2:

    • 输入:n = 0
    • 输出:0

六【解题思路】

  • 本题有一定难度,我第一次使用暴力解法, O ( n ) O(n) O(n)的时间复杂度,逐一判断每一个数字1的个数,最后超时了,显然需要换一个思路
  • 为了降低时间复杂度,就不能一个一个的处理,而是要分批处理,主要思路是求出个、十、百……每一位1的个数,最后求和就可以了
  • 当数位为 1 0 k 10^k 10k时(可能是个、十、百……任意一位),最后的 k k k位数字每 1 0 k + 1 10^{k+1} 10k+1个数字就会循环一次,而且其中包括 1 0 k 10^k 10k个1,那我们就要求 n n n中有多少个这样的循环,可用除法实现: ⌊ n 1 0 k + 1 ⌋ \left\lfloor\frac{n}{10^{k+1}}\right\rfloor 10k+1n,这样这一部分1的个数就是: ⌊ n 1 0 k + 1 ⌋ × 1 0 k \left\lfloor\frac{n}{10^{k+1}}\right\rfloor × 10^k 10k+1n×10k
  • 刚才处理了在循环内1的个数,那么不在循环内的呢?也就是剩余的 n   m o d   1 0 k + 1 n \bmod 10^{k+1} nmod10k+1个数,这一部分1的个数应为 n   m o d   1 0 k + 1 − 1 0 k + 1 n \bmod 10^{k+1} - 10^k + 1 nmod10k+110k+1,剩余的这些数有几种情况:
    • 上式的值小于0,那么就将此值调整为1出现0次,说明1没出现过
    • 上式的值大于 1 0 k 10^k 10k,说明1出现了 1 0 k 10^k 10k
    • 还有另一个不确定的阈值,要根据位数去判断,如果上式的值不仅大于 1 0 k 10^k 10k,还大于此阈值,说明1出现的次数最多就是此阈值对应的出现次数,所以应该在两者中取最小
  • 根据以上思路就可得到计算公式:
    ⌊ n 1 0 k + 1 ⌋ × 1 0 k + min ⁡ ( max ⁡ ( n   m o d   1 0 k + 1 − 1 0 k + 1 , 0 ) , 1 0 k ) \left\lfloor\frac{n}{10^{k+1}}\right\rfloor \times 10^{k}+\min \left(\max \left(n \bmod 10^{k+1}-10^{k}+1,0\right), 10^{k}\right) 10k+1n×10k+min(max(nmod10k+110k+1,0),10k)

七【题目提示】

  • 0 < = n < = 1 0 9 0 <= n <= 10^{9} 0<=n<=109

八【时间频度】

  • 时间复杂度: O ( l o g n ) O(logn) O(logn),其中 n n n为传入参数的大小
  • 空间复杂度: O ( 1 ) O(1) O(1)

九【代码实现】

  1. Java语言版
class Solution {
    public int countDigitOne(int n) {
        long mul = 1;
        int res = 0;
        for(int k = 0;mul<=n;k++){
            res += (n / (mul * 10)) * mul + Math.min(Math.max(n % (mul * 10) - mul + 1,0),mul);
            mul *= 10;
        }
        return res;
    }
}
  1. C语言版
int countDigitOne(int n)
{
    long mul = 1;
    int res = 0;
    while(mul <= n)
    {
        res += (n / (mul * 10)) * mul + fmin(fmax(n % (mul * 10) - mul + 1,0),mul);
        mul *= 10;
    }
    return res;
}
  1. Python版
class Solution:
    def countDigitOne(self, n: int) -> int:
        mul = 1
        res = 0
        while mul <= n:
            res += (n // (mul * 10)) * mul + min(max(n % (mul * 10) - mul + 1,0),mul)
            mul *= 10
        return res

十【提交结果】

  1. Java语言版
    在这里插入图片描述

  2. C语言版
    在这里插入图片描述

  3. Python语言版
    在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/151726.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

为你的Typecho使用Redis缓存,优化访问速度-织音博客

前言Typecho虽然轻量&#xff0c;但终究仍是PHP动态脚本&#xff0c;访问时需要频繁调取数据库的信息&#xff0c;导致并发值一高&#xff0c;CPU就100%占用&#xff0c;无法处理新的请求信息。这时&#xff0c;我们可以用Redis来设置缓存&#xff0c;从而不用频繁调动数据库&a…

【Meetup预告】SeaTunnel + OpenMLDB:共筑数据集成生态,加速实时场景落地

2023年1月12日&#xff08;周四&#xff09;20&#xff1a;00-21:30&#xff0c;云原生数据集成平台 SeaTunnel 联合开源机器学习数据库 OpenMLDB 合作带来本期 Meetup。 活动背景 Al 应用的繁荣发展&#xff0c;既得益于数据的爆发式增长&#xff0c;也受困于数据治理的种种…

使用Bokeh进行数据可视化的8个建议(上)

使用 Bokeh 库创建数据可视化的快速提示和示例。 长按关注《Python学研大本营》&#xff0c;加入读者群&#xff0c;分享更多精彩 扫码关注《Python学研大本营》&#xff0c;加入读者群&#xff0c;分享更多精彩 Python 是创建数据可视化的绝佳开源工具。有许多可用的数据可视…

JavaWeb:会话技术之Cookie

1&#xff0c;会话跟踪技术的概述 对于会话跟踪这四个词&#xff0c;我们需要拆开来进行解释&#xff0c;首先要理解什么是会话&#xff0c;然后再去理解什么是会话跟踪&#xff1a; 会话&#xff1a;用户打开浏览器&#xff0c;访问web服务器的资源&#xff0c;会话建立&…

设计模式-到底什么是builder模式

我们来看一个一些常见的开源代码中带builder字样的经典类&#xff1a;&#xff08;jdk&#xff09;Stringbuilder&#xff08;spring&#xff09;springApplicationBuilder&#xff08;es&#xff09;xxxQuerybulider如果只去看这些类的话&#xff0c;应该是一团乱码&#xff0…

【Kotlin】字符串操作 ① ( 截取字符串函数 substring | 拆分字符串函数 split | 解构语法特性 )

文章目录一、截取字符串函数 substring二、拆分字符串函数 split一、截取字符串函数 substring Kotlin 中提供了 截取字符串函数 substring , 可接收 IntRange 类型的参数 , 这是 整数范围 类型 ; 截取字符串函数 substring 函数原型为 : /*** 返回由给定的[range]索引指定的…

【pat】网红点打卡攻略【图】

一个旅游景点&#xff0c;如果被带火了的话&#xff0c;就被称为“网红点”。大家来网红点游玩&#xff0c;俗称“打卡”。在各个网红点打卡的快&#xff08;省&#xff09;乐&#xff08;钱&#xff09;方法称为“攻略”。你的任务就是从一大堆攻略中&#xff0c;找出那个能在…

【MyBatis】第一篇:初体验

还是老规矩看一下百度百科中的解释&#xff1a; MyBatis 是一款优秀的持久层框架&#xff0c;它支持定制化 SQL、存储过程以及高级映射。MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。MyBatis 可以使用简单的 XML 或注解来配置和映射原生信息&#xff0c…

Web(三)

JavaScript基础概念&#xff1a;一门客户端脚本语言* 运行在客户端浏览器中的。每一个浏览器都有JavaScript的解析引擎* 脚本语言&#xff1a;不需要编译&#xff0c;直接就可以被浏览器解析执行了功能&#xff1a;* 可以来增强用户和html页面的交互过程&#xff0c;可以来控制…

蓝桥杯C51

#include "reg52.h"sfr AUXR 0x8e; //定义辅助寄存器sbit S5 P3^2; //定义按键S5引脚 sbit S4 P3^3; //定义按键S4引脚unsigned char count 0; //定义中断计数器 unsigned char t_h 0; //定义运行时间的变量 unsigned char t_m 0; …

Struts2之OGNL表达式

Struts2之OGNL表达式1、什么是OGNL表达式2、OGNL表达式的作用3、值栈与OGNL3.1、值栈3.2、OGNL访问值栈4、类型转换4.1、类型转换的意义4.2、内置的类型转换器4.3、自定义类型转换器4.3.1、创建日期转换器4.3.2、配置转换器4.3.3、页面4.3.4、实体类和Action控制器4.3.5、strut…

从0到1完成一个Vue后台管理项目(七、Header、Footer、页面布局)

往期 从0到1完成一个Vue后台管理项目&#xff08;一、创建项目&#xff09; 从0到1完成一个Vue后台管理项目&#xff08;二、使用element-ui&#xff09; 从0到1完成一个Vue后台管理项目&#xff08;三、使用SCSS/LESS&#xff0c;安装图标库&#xff09; 从0到1完成一个Vu…

2010-2020年和讯网分行业社会责任指数

2010-2020年和讯网分行业社会责任指数 1、时间&#xff1a;2010-2020年 2、行业包括&#xff1a; 银行业&#xff08;III&#xff09;、人寿保险&#xff08;III&#xff09;、普通金融服务、工业运输、采矿业、饮料、不动产、食品与药品零售、电力&#xff08;III&#xff…

JS字符串的截取出现的bug

前言 在js中我们对字符串进行一部分截取&#xff0c;可以使用slice()函数截取&#xff0c;也可以直接用substring()函数来截取&#xff0c;但是截取也有可能出bug const str小&#x20bb7;和小&#x27a01;今天吃了50块钱的KFC console.log(str.slice(0,5)); 可以在控制台看…

ESP-IDF:数组为空异常处理例程

1.需要开启对ESP-IDF 中的 C 异常的支持。 默认情况下禁用对 ESP-IDF 中的 C 异常的支持,但可以使用 CONFIG_CXX_EXCEPTIONS 选项启用. 如果禁用对 ESP-IDF中的 C 异常的支持这样编译例程会报错&#xff1a; error: exception handling disabled, use -fexceptions to enable…

node.js中的文件读取写入操作

fs文件系统模块 什么是fs文件系统模块 fs模块是node.js官方提供的、操作文件的模块。通过fs模块可以实现对文件的读取以及写入操作。 例如&#xff1a; fs.readFile():用于读取指定文件的文件内容fs.writeFile()&#xff1a;用于向指定的文件写入内容 引入fs模块&#xff…

[2023] NAND闪存及控制器的市场趋势

一、NAND闪存市场分析据欧洲知名半导体分析机构Yole发布的报告显示&#xff0c;2020年起&#xff0c;NAND闪存市场发展趋势保持稳定增长&#xff0c;2021年&#xff0c;NAND闪存市场份额达到了近670亿美元&#xff08;见图1&#xff09;&#xff0c;同年&#xff0c;NAND闪存总…

使用 Vagrant 对 VirtualBox 虚拟机磁盘扩容

使用Vagrant 对 VirtualBox 磁盘扩容 Vagrant 下载地址: https://www.vagrantup.com/downloads.html Vagrant版本 2.3.4 VirtualBox版本&#xff1a;7.0.4 1、在初次使用 Vagrant init 创建 VirtualBox 虚拟机时&#xff0c;会创建一个 Vagrantfile 文件 2、在 Vagrantfile…

CAS:60842-46-8;葡聚糖-荧光素;Dextran-FITC

Dextran-FITC、葡聚糖-荧光素、&#xff08;葡聚糖-FITC&#xff09; CAS NO: 60842-46-8 英文名称&#xff1a;&#xff1a; Dextran(3,6dihydroxy-3-oxospiro(isobenzofuran-1(3H],9-[9H]xanthen]-5(or 6]-yl]carbamothioate, average Mw of approximately 分子量&#xf…

java 微服务之docker基础入门 docker部署 镜像相关命令 容器命令 数据卷 DockerCompose Docker镜像仓库

初识Docker 项目部署的问题 什么是Docker 不同环境的操作系统不同&#xff0c;Docker如何解决&#xff1f;我们先来了解下操作系统结构 Docker与虚拟机 虚拟机是在一个系统内&#xff0c;运行另外一个系统 镜像和容器 镜像&#xff08;Image&#xff09;&#xff1a;Docker将…