剑指offer实践 ——44.数字序列中某一位的数字(python版)

该博客介绍了如何通过Python解决数字序列中查找特定位置n的数字问题。博主首先分析了数字序列的规律,然后通过确定n位于哪一位数的数字、在该位数中是第几个以及在该数字的哪一位来解决问题。通过循环和数学运算,实现了O(logn)的时间复杂度解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >



题目

数字序列中某一位的数字
在这里插入图片描述


一、思路 找呀找呀找规律

由于数字是从0到无限的数字递增排列的,而0~9的数字只有一位,但是·10~99的数字有两位,100~999的数字有三位……因此给定一个n,确定在这个序列中第n位在什么位置,需要:
1.确定这个n位在几位数字中
2.确定这个n位在几位数字中的那一个数字中
3.确定这个n位在几位数字中的那一个数字中的那一位

例如:
寻找第13位数字。
0~9共有9个数字,而第13位>9,所以在10~99中寻找
10~99中每一个数字有2位,13-9=4,4/2=2(上取整),证明n位在10~99中的第二个数字,所以定位到了11这个数字。
11这个数字有2位,4%2=0。所以定位到了11这个数字的最后一位。
在这里插入图片描述

1.看一下数位的规律。
在这里插入图片描述
定义digit=1, start = 1,count=9,首先定位当前这个n属于那一个位数的数字,及确定digit
另n =

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值