当前位置: 首页 > article >正文

leetcode400第N位数字

代码 

class Solution {
    public int findNthDigit(int n) {
        int base = 1;//位数
        int weight = 9;//权重
        while(n>(long)base*weight){//300
            n-=base*weight;
            base++;
            weight*=10;
        }
        //n=111 base=3 weight=900;
        n--;
        int res = (int)Math.pow(10,base-1)+n/base;
        int index = n%base;
        return String.valueOf(res).charAt(index)-'0';
    }
}

思路(包懂嘟因为mikey都懂)

1. 确定 nnn 所在的位数段
  • 初始化

    • base = 1 表示当前数字段的位数(从 1 开始)。
    • weight = 9 表示当前段所有数字占用的总位数。
  • 循环条件n > base * weight

    • nnn 比当前段所占的总位数大,说明 nnn 不在当前位数段。
    • 减去当前段的总位数后,继续检查下一段。
  • 更新规则

    • 减去当前段的总位数:n -= base * weight
    • 位数加 1:base++
    • 更新权重:weight *= 10(下一段的数字数量增加了 10 倍)。

示例:当 n=300时,

  • 初始:base = 1, weight = 9,剩余 n=300−9=291。
  • 更新:base = 2, weight = 90,剩余 n=291−180=111。
  • 更新:base = 3, weight = 900,此时 n=111,不再减去。

此时可以确定,n 位于 3 位数段(100 ~ 999)。


2. 定位到具体数字

在确定 nnn 位于当前位数段后:

  • 进行 n-- 操作,将索引调整为从 0 开始
    • 这是因为自然序列是从 1 开始,而数字的位是从 0 开始计数的。
  • 使用公式确定数字:
    • res = (int)Math.pow(10, base-1) + n / base
      • Math.pow(10, base-1)表示当前段的起始数字。
      • n/base表示 n超出当前段起始的完整数字个数。
      • 两者之和 res 就是目标数字。

示例:当 n=111且 base=3时:

  • 进行 n--,得到 n=110。
  • res = 100 + 110 / 3 = 100 + 36 = 136

3. 提取数字中的具体位

最后一步是从计算得到的数字中提取 nnn 对应的位:

  • index = n % base 计算数字中的具体位索引。
  • 转换为字符串,提取对应字符:String.valueOf(res).charAt(index) - '0'

示例:数字 136,索引 n=110,

  • index=110%3=2。
  • 对应数字 136 的第 2 位是 6。

因此返回结果 6。


http://www.kler.cn/a/401967.html

相关文章:

  • 2024年11月19日Github流行趋势
  • 网络基础(3)https和加密
  • Pytest 学习 @allure.severity 标记用例级别的使用
  • SSD固态硬盘删除文件基本无法恢复
  • 七、箭头函数及简写、arguments、剩余参数、展开运算符、解构数组与对象、数组常见方法(forEach、map、join、reduce)
  • 计算机视觉和机器人技术中的下一个标记预测与视频扩散相结合
  • [Go实战]:SSE消息推送
  • 聚类分析 | MSADBO优化Spectral谱聚类优化算法
  • 群控系统服务端开发模式-应用开发-前端级别功能开发
  • 小红书内容推荐算法开发:利用API打造个性化用户体验
  • Android全局异常捕获
  • Android中常见内存泄漏的场景和解决方案
  • 代码辅助工具 GPT / Cursor
  • AWS EC2 ubuntu 使用密码登陆
  • 24.11.14 朴素贝叶斯分类 决策树-分类
  • 【算法】动态规划中01背包问题解析
  • uniapp 自定义加载组件,全屏加载,局部加载 (微信小程序)
  • git 基础之 merge 和 rebase 的比较
  • 运维面试题.云计算面试题之三ELK
  • VGG16-Pytorch实现人脸识别
  • C/C++实现tcp客户端和服务端的实现(从零开始写自己的高性能服务器)
  • AI 驱动低代码平台:开创智能化用户体验新纪元
  • vue功能基础元素使用
  • Java中日志采集框架-JUL、Slf4j、Log4j、Logstash
  • 在 macOS 和 Linux 中,波浪号 `~`的区别
  • 使用C++编写一个程序,模拟掷骰子的过程,输出1到6之间的随机数。