《剑指offer第二版》题44:找寻数字序列中某一位的数字笔记记录

题目:

数字以0123456789101112131415…的格式序列化到一个字符序列中。在这个序列中,第5位(从下标0开始计数)是5,第13位是1,第19位是4,等等。请写一个函数,求任意第n位对应的数字。题目链接

1.解题步骤

解题步骤主要分为三步:

①求出第n位对应的数number的位数

②求出第n位对应的数number

③求出第n位对应数number的哪一个数字

2.数字,位数,位数数量之间的关系

通过列表格的形式来找到这几个关键点之间的联系:

数字范围位数digit数字数量位数数量count
1-9199
10-99290180
100-99939002700
start-endn9 x start9 x start x end

通过表格就可以看出第n位和位数数量之间存在范围关系:如果1<n<9,说明number位数为1位,如果9<n<189(180+9,n为累加),说明number位数为2位,以此类推。所以可以通过判断n的大小范围,得到位数。

3. 确定位数digit的代码实现

digit, start, count = 1, 1, 9
while n > count:
    n -= count
    digit += 1
    start *= 10
    count = 9 *start * digit

通过while循环得到的digit就是第n位对应的数字number的位数。

4.确定对应的数字number的代码实现

number = start + (n-1) // digit

start对应的就是位数为digit的第一个数字,只要确定number是start开始的第几个数字,就能确定number的值。注意:while循环结束后的n已经为从start开始计算的下标

number(每一格表示一位)10111213
n12345678
n-101234567
(n-1)//digit00112233

 

(n-1)//digit刚好表示了自strat开始的第几个数字。

5. 确定n表示number的第几个数字代码实现

巧妙点:通过将number字符串化,使得number每一位都有了位置下标可以直接寻找到

sing = str(number)
res = int(sing[(n-1) % digit])

6.整体代码

class Solution:
    def findNthDigit(self, n: int) -> int:
        digit, start, count = 1, 1, 9
        while n > count:
            n -= count
            digit += 1
            start *= 10
            count = 9 * start * digit
        num = start + (n-1) // digit
        sing = str(num)
        res = int(sing[(n-1)%digit])
        return res

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值