2025年--Lc216- 400. 第 N 位数字(找规律)-Java版

1.题目

2.思路

(1)1位数 1~9,9个数,总位数19=9
(2)2位数,10~99,90个数,总位数2
90=180

(3)3位数,100~999,900个数,总位数3*900=2700

d当前遍历到的位数,count当前位数下的所有整数的位数之和。

初始时 d=1,count=9。每次将 n 减去 d×count。

然后将 d 加 1,将 count 乘以 10,直到 n≤d×count。

此时的 d 是目标数字所在整数的位数,n 是所有 d 位数中从第一位到目标数字的位数。

3.代码实现

java 复制代码
class Solution {
    public int findNthDigit(int n) {
        int d=1;//代表当前是一位数
        int cnt=9;
        if(n<=9)
        {
            return n;
        }
        while(n>(long)d*cnt)//如果n>9的话
        {
            n=n-d*cnt;
            d++;//位数+1
            cnt=cnt*10;//当前范围内的数字个数*10
        }
        int index=n-1;
        //Math.pow(a, b):是 Java 中 java.lang.Math 类提供的静态方法,用于计算 a 的 b 次幂(即 a^b),返回值为 double 类型。
        int begin=(int)Math.pow(10,d-1);
        int num=begin+index/d;
        int digitIndex=index%d;
        int digit=(num/(int)(Math.pow(10,d-digitIndex-1)))%10;
        return digit;
        
    }
}
相关推荐
扫地的小何尚1 天前
NVIDIA RTX PC开源AI工具升级:加速LLM和扩散模型的性能革命
人工智能·python·算法·开源·nvidia·1024程序员节
数据皮皮侠AI2 天前
上市公司股票名称相似度(1990-2025)
大数据·人工智能·笔记·区块链·能源·1024程序员节
开开心心就好3 天前
系统清理工具清理缓存日志,启动卸载管理
linux·运维·服务器·神经网络·cnn·pdf·1024程序员节
Evan东少5 天前
[踩坑]笔记本Ubuntu20.04+NvidiaRTX5060驱动+cuda+Pytorch+ROS/Python实现人脸追踪(环境准备)
1024程序员节
不爱编程的小陈7 天前
C/C++每日面试题
面试·职场和发展·1024程序员节
开开心心就好7 天前
右键菜单管理工具,添加程序自定义名称位置
linux·运维·服务器·ci/cd·docker·pdf·1024程序员节
码农三叔8 天前
(4-2-05)Python SDK仓库:MCP服务器端(5)Streamable HTTP传输+Streamable HTTP传输
开发语言·python·http·大模型·1024程序员节·mcp·mcp sdk
西幻凌云12 天前
初始——正则表达式
c++·正则表达式·1024程序员节
启芯硬件12 天前
电源XL6009E1的dieshot细节分析-芯片设计干货
大数据·经验分享·硬件工程·1024程序员节
一颗青果14 天前
单例模式 | 死锁
linux·服务器·单例模式·1024程序员节