剑指offer—43.整数中1出现的次数(从1到n整数中1出现的次数)—分析及代码(Java)_剑指offer43递归-程序员宅基地

技术标签: 剑指offer  Java  题解  数据结构与算法  

剑指offer——43.整数中1出现的次数(从1到n整数中1出现的次数)——分析及代码[Java]

一、题目

求出 1 ~ 13 的整数中 1 出现的次数, 并算出 100 ~ 1300 的整数中 1 出现的次数?为此他特别数了一下 1 ~ 13 中包含 1 的数字有 1、10、11、12、13 因此共出现 6 次, 但是对于后面问题他就没辙了。ACMer 希望你们帮帮他, 并把问题更加普遍化, 可以很快的求出任意非负整数区间中 1 出现的次数(从 1 到 n 中 1 出现的次数)。

二、分析及代码

1. 按位递归

(1)思路

可以对整数 n 的各个十进制位依次进行处理。
若第 k 位的数字为 a,即 n / (10 ^ k) = a,则在连续的 a * 10 ^ k 个数字中,数字 1 的个数为 a * k * 10 ^ (k - 1) 个(可理解为选择其中一位数字为 1,其他 k - 1 位可以有 10 ^ (k - 1) 种排列方式)。
结合上述算法,通过递归即可求出从 1 到 n 中 1 出现的次数。

(2)代码

public class Solution {
    
    public int NumberOf1Between1AndN_Solution(int n) {
    
        if (n <= 0)
            return 0;
        int num = n / 10, k = 10, b = 1, ans = 0;
        if (n % 10 != 0) //个位特殊处理,从十位开始可用通用算法
            ans++;
        
        while (num != 0) {
    
            int a = num % 10;
            if (a == 1)
                ans += a * b * k / 10 + n % k + 1;
            else if (a == 0)
                ans += 0;
            else
                ans += k + a * b * k / 10;
            num = num / 10;
            k *= 10;
            b++;
        }
        return ans;
    }
}

(3)结果

运行时间:23ms,占用内存:9428k。

三、其他

暂无。

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/zml66666/article/details/108687705

智能推荐

基于SQL Server数据库的安全性对策探究_sqlserver数据库的安全性-程序员宅基地

文章浏览阅读438次。SQL Server数据库的安全与计算机网络安全、数据库系统安全等存在一定的联系,某一环节的安全隐患对整个系统的安全造成一定威胁,因此对数据库安全方面采取防范措施具有一定的必要性,与当下网络信息安全管理方面的要求相适应,它可以为用户提供稳定、安全的网络环境。在数据库系统中,管理者如果从用户界面进入系统,存在的数据库安全问题与使用者面临的安全问题相同,但如果管理者从数据库管理界面进入系统的话,由于这种情况下管理者的权限比较大,如果从数据库服务器的DBMS进入数据库的话,对数据库安全存在比较大的威胁。_sqlserver数据库的安全性

java计算圆锥体积_【身临其境】关于几何体的表面积和体积,就没见过这么详细的解释!!!...-程序员宅基地

文章浏览阅读627次。点击上方蓝色字体“高中数学王晖”关注王晖老师,免费获取各种知识干货和学习经验~~~您的点赞转发是对老师的最大鼓舞~~~距高考还有168天从展开图看几何体表面积基本要求:①理解柱、锥、台体的侧面展开图;②掌握柱、锥、台、球表面积常用公式;③能计算简单组合体的表面积。直棱柱展开直棱柱的侧面展开后,整体的外观形状是矩形。所以,直棱柱的表面积就比较方便计算了:直棱柱表面积=侧面积+2×底面积直棱..._java圆锥体积

dubbo端口冲突解决办法_dubbo 多个服务抢占端口-程序员宅基地

文章浏览阅读2.8k次。在一台机子上部署多个dubbo服务,将各服务的dubbo端口号设为-1,可以确保无端口冲突。_dubbo 多个服务抢占端口

【CISSP备考】第七章-安全运营_cissp sox法案-程序员宅基地

文章浏览阅读2.1k次。第六章密码学和对称秘钥算法:密码可为已存储(静止中)、通过网络传送(传输中)和存在于内存中(使用中)的敏感信息提供保密性、完整性、身份验证和不可否认性保护。凯撒密码:将相关字母顺移密码学的目标:保密性、完整性、身份验证和不可否认性1、保密性:保密性是确保数据在静止、传输和使用等三种不同状态下始终保持私密对称加密系统、非对称加密系统2、完整性完整性确保数据没有被人未经授权更改、消息完整性使用加密的消息摘要实现3、身份验证身份验证用于验证系统用户所声称的身份,是密码系_cissp sox法案

微信小程序开发:实现地图导航功能_微信小程序地图导航功能实现-程序员宅基地

文章浏览阅读4.8k次,点赞2次,收藏25次。其中,id用于调用地图组件,latitude和longitude表示地图的中心点坐标,markers表示地图中的标记点,covers表示地图中的覆盖物,polyline表示地图中的折线图,show-location表示是否显示当前定位点,bindregionchange表示移动地图时触发的事件。其中,id表示标记点的唯一标识,latitude和longitude表示标记点的坐标,title表示标记点的名称,iconPath表示标记点的图标路径,width和height表示标记点的宽度和高度。_微信小程序地图导航功能实现

Invalid initial heap size: -Xms-程序员宅基地

文章浏览阅读4.9k次。-Xxs512m注意 Xxs 和 512m中间无空格就行了。_invalid initial heap size: -xms4g

随便推点

ROS——树莓派4B使用思岚A1激光雷达和乐视深度相机_rplidar a1使用hector_mapping-程序员宅基地

文章浏览阅读5k次,点赞4次,收藏108次。文章目录1.运行并测试RPLIDAR A1激光雷达2.使用RPLIDAR A1激光雷达测试hector_mapping务必使用远程桌面进行launch文件的运行,因为会需要用到rviz界面,如果用putty会报错!1.运行并测试RPLIDAR A1激光雷达ROS中使用激光雷达(RPLIDAR)测试效果:2.使用RPLIDAR A1激光雷达测试hector_mapping思岚RPLIDAR S1测试hector_mapping(rviz上渲染显示周围环境)需要注意的是,因为我使用的是RPL_rplidar a1使用hector_mapping

OpenCV Mat数据的按行(列)和多行(列)赋值_mat修改整列-程序员宅基地

文章浏览阅读2.7w次,点赞24次,收藏34次。赋值的不正确情况在使用opencv的过程中,希望多行或者多列进行赋值,我之前的代码是这样的 Mat c = Mat::zeros(3, 5, CV_32F); Mat a = Mat::ones(3, 6, CV_32F); //对a的第一列进行赋值 a.col(0) = c.col(0); //将c的1-5列赋值给a a.colRange(1, 6)_mat修改整列

C语言之输入一个年份,判断是不是闰年_如何判断闰年c语言-程序员宅基地

文章浏览阅读3.1w次,点赞5次,收藏11次。#include int main(){/*输入年份判断是不是闰年*//*闰年:能被400整除, 能被4整除,并且不能被100整除*/ int year,flag; printf("请输入一个年份\n"); scanf("%d",&year); if(year%400==0){ flag=1; }else{ if(year%4==0){_如何判断闰年c语言

LIN协议介绍-程序员宅基地

文章浏览阅读929次。LIN协议介绍_lin协议

Node.js开发概述-程序员宅基地

文章浏览阅读1.4k次。Node.js发布于2009年5月,由Ryan Dahl开发,是一个基于Chrome V8引擎的JavaScript运行环境,使用了一个事件驱动、非阻塞式I/O模型, [1] 让JavaScript 运行在服务端的开发平台,它让JavaScript成为与PHP、Python、Perl、Ruby等服务端语言平起平坐的脚本语言。 [2] Node.js对一些特殊用例进行优化,提供替代的API,使得V8在非浏览器环境下运行得更好,V8引擎执行Javascript的速度非常快,性能非常好,基于Chrome Ja_node.js开发

SVN不完全指南(使用)_svn authz文件在哪-程序员宅基地

文章浏览阅读238次。目录一 、SVN三大指令(检提更) 二、忽略功能 三、版本回退 四、版本冲突 五、配置多仓库与权限控制 六、SVN服务的配置与管理 七、模拟真实的开发环境一 、SVN三大指令(检提更)检出(Checkout)操作 首先在你的项目目录鼠标右键TortoiseSVN版本库浏览器输出SVN服务器地址: svn://SVN服务器地址 Shop项目(仓库) 注: 因为.svn是隐藏_svn authz文件在哪

推荐文章

热门文章

相关标签