我需要在python中编写一个程序,给定一个整数作为输入,计算从1开始并持续到无穷大的连续自然数行中的数字(例如12345678910111213141516171819202122等......)例如,如果我们输入17,它会计算该行的第 17 位,即 3。
我编写了一个程序,可以计算到第 189 位,但我需要将其计算为非常大的数字(直到位置 2**31-1)
def digit_finder():
if pos < 10: #Position is equal to digit.
digit=pos
return(digit)
elif pos >= 10 en pos < 189: #Number between 10 and 99.
number=(pos-9)
if pos%2==0:
new_number=(10+(number//2))
digit=(new_number//10)
return digit
else:
new_number=(9+(number//2))
digit=(new_number-((new_number//10)*10))
return digit
我不知道如何继续更大的数字。请帮忙 !