题解 | #数字序列中某一位的数字# 简单、直观、易理解

数字序列中某一位的数字

https://www.nowcoder.com/practice/29311ff7404d44e0b07077f4201418f5

class Solution {
  public:
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     *
     * @param n int整型
     * @return int整型
     */
    int findNthDigit(long long n) {
        if (n < 10) {
            return n;
        }
        // 按照十进制占的bit数量依次梳理各个区间:[0, 10) [10, 100) [100, 1000), [1000, 10000)....
        long long min = 0;
        long long max = 10;
        long long count = max - min; // 转成string后[min, max)区间内总bit数

        long long bits = 1; // 对应 [min, max) 区间的每个数组转成string后占的bit数
        while (n >= count) {
            n -= count;

            ++bits; 

            min = max;
            max = min * 10;
            count = (max - min) * bits;
        }
        
        // 计算目标对应当前区间第几个数字,以及返回这个数字的第几位
        long long th = n / bits;
        long long bit_th = n % bits;
      
       long long target = min + th;
        std::string tmp(std::to_string(target));
        return tmp.at(bit_th) - '0';
    }
};

code中有些变量是非必须的,但是为了方便理解,这里保留了一些冗余的变量

全部评论

相关推荐

鼠鼠第一次实习,啥也不懂一直是自己一个人吃的饭,不会做工作老是被嫌弃,大人的世界是这样的吗?
我是星星我会发亮:好的mt有两种,一种愿意教你的,一种几乎什么活都不给你派让你很闲允许你做自己事情的
实习吐槽大会
点赞 评论 收藏
分享
鬼迹人途:你去投一投尚游游戏,服务器一面,第一个图算法,做完了给你一个策略题,你给出方案他就提出低概率问题,答不上当场给你挂
点赞 评论 收藏
分享
06-13 10:15
门头沟学院 Java
想去夏威夷的大西瓜在...:我也是27届,但是我现在研一下了啥项目都没有呀咋办,哎,简历不知道咋写
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务