🧮 Algorithm Notebook
1、算法准备
1.1 牛客网编程OJ的典型输入输出
2、算法框架
2.1 动态规划
2.1.1 斐波那契数列
2.1.2 背包问题
2.1.3 贪心算法
2.1.4 序列和数组类问题
2.1.5 编辑距离
2.1.6 高楼扔鸡蛋
2.1.7 股票问题系列通解
2.1.8 最长有效括号
2.1.9 剪绳子
2.1.10 正则表达式匹配
2.2 二分查找
2.2.1 二分查找框架
2.2.2 搜索旋转排序数组
2.3 链表
2.3.1 反转链表
2.3.2 相交链表
2.3.3 合并链表
2.3.4 链表中倒数第k个节点
2.3.5 复制带随机指针的链表
2.4 排序算法
2.4.1 常见排序算法
2.5 二叉树
2.5.1 二叉树遍历
2.5.2 岛屿问题
2.5.3 二叉树路径问题
2.5.4 构造二叉树
2.6 回溯算法
2.6.1 回溯算法解题框架
2.6.2 N皇后
2.7 数组
2.7.1 删除有序数组中的重复项
2.7.2 滑动窗口最大值
2.7.3 调整数组顺序使奇数位于偶数前面
2.7.4 螺旋矩阵
2.7.5 多数元素
2.7.6 最大数
2.7.7 和为s的两个数字
2.7.8 构建乘积数组
2.7.9 两数之和
2.8 字符串
2.8.1 最小覆盖子串
2.8.2 比较版本号
2.8.3 验证IP地址
2.8.4 基本计算器 II
2.8.5 字符串解码
2.8.6 移掉 K 位数字
2.8.7 无重复字符的最长子串
2.8.8 第一个只出现一次的字符
2.8.9 翻转字符串里的单词
2.8.10 字符串转换整数 (atoi)
2.8.11 字符串四则运算
2.9 栈
2.9.1 最小栈
2.9.2 弹出序列
2.10 数学
2.10.1 用 Rand7() 实现 Rand10()
2.10.2 只出现一次的数字
2.10.3 整数反转
2.10.4 求1+2+…+n
2.10.5 二进制中1的个数
2.10.6 幂运算
2.10.7 1~n 整数中 1 出现的次数
2.10.8 数字序列中某一位的数字
2.10.9 丑数
2.10.10 n个骰子的点数
2.10.11 圆圈中最后剩下的数字
2.10.12 不用加减乘除做加法
2.10.13 x 的平方根
2.11 设计
2.11.1 LRU 缓存机制
-
+
游客
注册
登录
数字序列中某一位的数字
## 1 题目 数字以 0123456789101112131415…的格式序列化到一个字符序列中。在这个序列中,第 5 位(从下标 0 开始计数)是 5,第 13 位是 1,第 19 位是 4,等等。 请写一个函数,求任意第 n 位对应的数字。 **示例 1:** ```txt 输入:n = 3 输出:3 ``` **示例 2:** ```txt 输入:n = 11 输出:0 ``` **限制:** * 0 <= n < 2^31 ## 2 问题分析 1. 相应的数字定义如下: 1. **将 $ 101112 \cdots$ 中的每一位称为数位**,**记为 $n$**。 2. **将 $ 10, 11, 12, \cdots$ 称为数字**,**记为 $num$**。 3. **数字 $ 10 $ 是一个两位数**,**称此数字的位数为 2**,**记为 $digit$**。 4. **每 $digit$ 位数的起始数字**(即 $ 1, 10, 100, \cdots$),**记为 $start$**。 ![Picture1.png](/media/202202/2022-02-09_1733270.5518137850928253.png) 2. 根据以上分析,可将求解分为三步: 1. **确定 $n$ 所在数字的位数**,**记为 $digit$**: 1. **循环执行 $n$ 减去一位数**、**两位数**、...**的数位数量 $count$**,**直至 $n \le count$ 时跳出**。 2. **由于 $n$ 已经减去了一位数**、**两位数**、...、$(digit - 1)$**位数的数位数量 $count$**,**因而此时的 $n$ 是从起始数字 $start$ 开始计数的**。 ![Picture2.png](/media/202202/2022-02-09_1741260.942468520063812.png) 2. **确定 $n$ 所在的数字**,**记为 $num$**: 1. **所求数位在从数字 $start$ 开始的第 $\frac{n - 1}{digit}$ 个数字中**($start$ 为第 0 个数字),即 $$ num = start + \frac{n - 1}{digit} $$ ![Picture3.png](/media/202202/2022-02-09_1745320.31558270921165665.png) 3. **确定 $n$ 是 $num$ 中的哪一数位**,**并返回结果**: 1. **所求数位为数字 $num$ 的第 $\frac{n - 1}{digit}$ 位**(数字的首个数位为第 0 位)。 ![Picture4.png](/media/202202/2022-02-09_1749000.4903168084894265.png) 3. 具体实例如下: ![](/media/202202/2022-02-09_1749560.8402380541484955.png) ![](/media/202202/2022-02-09_1750080.9277916893013155.png) ![](/media/202202/2022-02-09_1750250.8687465615429757.png) ## 3 参考代码 ```java /** * 剑指 Offer 44. 数字序列中某一位的数字 * @param n 数字序列中的位数 * @return 数字序列中第 n 位的数字 */ public int findNthDigit(int n) { int digit = 1, res = 0; long start = 1, count = 9, num = 0; // 1. 确定 n 所在数字的位数 while (n > count) { n -= count; digit++; start *= 10; count = 9 * digit * start; } // 2. 确定 n 所在的数字 num = start + (n - 1) / digit; // 3. 确定 n 是 num 中的哪一数位 res = Long.toString(num).charAt((n - 1) % digit) - '0'; return res; } ``` ## 参考文献 1. [剑指 Offer 44. 数字序列中某一位的数字](https://leetcode-cn.com/problems/shu-zi-xu-lie-zhong-mou-yi-wei-de-shu-zi-lcof)。 2. [面试题 44. 数字序列中某一位的数字(迭代 + 求整 / 求余,清晰图解)](https://leetcode-cn.com/problems/shu-zi-xu-lie-zhong-mou-yi-wei-de-shu-zi-lcof/solution/mian-shi-ti-44-shu-zi-xu-lie-zhong-mou-yi-wei-de-6)。
ricear
2022年2月9日 17:53
©
BY-NC-ND(4.0)
转发文档
收藏文档
上一篇
下一篇
手机扫码
复制链接
手机扫一扫转发分享
复制链接
Markdown文件
分享
链接
类型
密码
更新密码