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

leetcode400第N位数字

代码 

class Solution {public int findNthDigit(int n) {int base = 1;//位数int weight = 9;//权重while(n>(long)base*weight){//300n-=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.lryc.cn/news/487829.html

相关文章:

  • 前端网页开发学习(HTML+CSS+JS)有这一篇就够!
  • CSS遮罩:mask
  • Swift闭包的本质
  • 时代变迁对传统机器人等方向课程的巨大撕裂
  • 【算法设计与分析实训】第1关:求序列的最大字段和
  • 【澜舟科技-注册/登录安全分析报告】
  • 【读书笔记-《网络是怎样连接的》- 7】Chapter3_2 路由器
  • Android Activity 基础接口知识和常见问题
  • 利用python 检测当前目录下的所有PDF 并转化为png 格式
  • 解决 Spring Boot 中 `Ambiguous mapping. Cannot map ‘xxxController‘ method` 错误
  • C++ 函数返回值优化
  • c++源码阅读__ThreadPool__正文阅读
  • 关于ES的查询
  • 数据结构初识
  • 保存数据到Oracle时报错ORA-17004: 列类型无效: 1111
  • Excel——宏教程(1)
  • 论文浅尝 | MindMap:知识图谱提示激发大型语言模型中的思维图(ACL2024)
  • 第6章:TDengine 标签索引和删除数据
  • 【微软:多模态基础模型】(5)多模态大模型:通过LLM训练
  • 海外带云仓多语言商城源码,多语言多商家云仓一键代发商城
  • android:taskAffinity 对Activity退出时跳转的影响
  • Apache Dolphinscheduler数据质量源码分析
  • solana链上智能合约开发案例一则
  • 使用 PyTorch 实现 ZFNet 进行 MNIST 图像分类
  • 车轮上的科技:Spring Boot汽车新闻集散地
  • IDEA2023 SpringBoot整合Web开发(二)
  • 国产三维CAD 2025新动向:推进MBD模式,联通企业设计-制造数据
  • ubuntu 之 安装mysql8
  • Flink Lookup Join(维表 Join)
  • Elasticsearch retrievers 通常与 Elasticsearch 8.16.0 一起正式发布!