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

数字序列中某一位的数字

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中有些变量是非必须的,但是为了方便理解,这里保留了一些冗余的变量

全部评论

相关推荐

2025-12-28 16:32
重庆邮电大学 Java
程序员花海:1.技能放最后,来面试默认你都会,技能没啥用 2.实习写的看起来没啥含金量,多读读部门文档,包装下 接LLM这个没含金量 也不要用重构这种 不会给实习生做的 3.抽奖这个还是Demo项目,实际在公司里面要考虑策略,满减,触发点,触发规则 库存 之类的,不是这个项目这么简单 4.教育背景提前,格式为 教育背景 实习 项目 技能 自我评价
简历被挂麻了,求建议
点赞 评论 收藏
分享
牛至超人:哈工大已经很棒了,不需要加括号了,然后咋没有实习经历呢?火速趁寒假整一段实习,导师不让就狠狠肘击
投了多少份简历才上岸
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

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