LeetCode Various 1

LeetCode T400.第N位数字

  

  总结一些杂题🎈

 

题目描述:

给你一个整数 n ,请你在无限的整数序列 [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, ...] 中找出并返回第 n 位上的数字。

 

示例:

输入:n = 11
输出:0
解释:11 位数字在序列 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, ... 里是 0 ,它是 10 的一部分。

 

思路:

正常思路进行计算位数会超时,采用二分操作又臃肿麻烦,这里学习(抄袭)了力扣大佬的解法:补零 使得每一个数字都是一样的长度

假设 n 为 0,当 n 为 1 位数时即0-9时,此时 n 为几输出几。

当 n 为 2 位数时,此时给0-9前都补一个0,即00-09,则多了10^1个0,则此时n+=10^1;

当 n 为 3 位数时,此时给00-99前都补一个0,即000-099,则多了10^2个0,则此时n+=10^2;

以此类推……  当当前位数 i 满足 i * pow(10, i) > n 时则退出循环 即此时 n 已经进入在当前位数的序列中。

通过 n / i 定位到目标数字n % i 定位到目标数字的目标位

 

代码:

复制代码
class Solution {
    public int findNthDigit(int n) {
        long k = n;
        for (int i = 1; ; i++) {
            if (i * Math.pow(10, i) > k) {
                return Long.toString((int)(k / i)).charAt((int)(k % i)) - '0';
            }
            k += Math.pow(10, i);
        }
    }
}
复制代码

 

posted @   HM-7  阅读(26)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
点击右上角即可分享
微信分享提示