400 Nth Digit 第N个数字

在无限的整数序列 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, ...中找到第 n 个数字。
注意:
n 是正数且在32为整形范围内 ( n < 231)。
示例 1:
输入:
3
输出:
3
示例 2:
输入:
11
输出:
0
说明:
第11个数字在序列 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, ... 里是0,它是10的一部分。
详见:https://leetcode.com/problems/nth-digit/description/
C++:

class Solution {
public:
    int findNthDigit(int n)
    {
        long long len = 1, cnt = 9, start = 1;
        while (len * cnt < n)
        {
            n -= len * cnt;
            ++len;
            cnt *= 10;
            start *= 10;
        }
        start += (n - 1) / len;
        string t = to_string(start);
        return t[(n - 1) % len] - '0';
    }
};

 参考:https://www.cnblogs.com/grandyang/p/5891871.html

posted on 2018-04-16 10:49  lina2014  阅读(165)  评论(0编辑  收藏  举报

导航