鱼C论坛

 找回密码
 立即注册
楼主: zltzlt

[已解决]Python:每日一题 340

[复制链接]
发表于 2020-3-1 22:54:39 | 显示全部楼层
fan1993423 发表于 2020-3-1 22:52
你知道正确答案吗?

我的方法应该是没错的,只是效率太低了,你也可以试试看
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-1 23:38:32 | 显示全部楼层
def test(n):
    x = 0
    str_result = ''
    while len(str_result) < n+1 :     
        str_result +=  str(x)
        x += 1
    return str_result[n]

n = int(input('输入一个非负整数:'))
test(n)
这个写完感觉是对的,在shell里运行函数没问题,不知道为啥直接运行.py就没结果

评分

参与人数 1荣誉 +3 鱼币 +3 收起 理由
zltzlt + 3 + 3

查看全部评分

小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-2 00:10:24 From FishC Mobile | 显示全部楼层
def f(n):
    return ((9*n-1)*pow(10,n+1)+10)/81
   
def get1(n,num):
    if ((9*n-1)*pow(10,n+1)+10)/81 > num or ((9*n-1)*pow(10,n+1)+10)/81 == num:
        return n
    else:
        return get1(n+1,num)

a = int(input())
leve = get1(1,a)
b = int(a - f(leve - 1) - 1)
num = int(b/leve+1)
l = int(leve-b%leve)

m = pow(10,leve)+num
end = int((m%pow(10,l))/pow(10,l-1))
print(end)

评分

参与人数 1荣誉 +2 鱼币 +2 收起 理由
zltzlt + 2 + 2

查看全部评分

小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-2 00:11:44 | 显示全部楼层
本帖最后由 fan1993423 于 2020-3-2 00:13 编辑
  1. def fun340(n):
  2.     if n<=9:return n
  3.     count=0
  4.     num_length=0
  5.     while n>count:
  6.         count+=(num_length+1)*9*10**num_length
  7.         num_length+=1
  8.     count-=num_length*9*10**(num_length-1)
  9.     left_num=n-count-1
  10.     a,b=divmod(left_num,(num_length*10**(num_length-1)))
  11.     record=str(a+1)
  12.     i=2
  13.     while num_length>=i:
  14.         first_num,second_num=divmod(b,num_length*10**(num_length-i))
  15.         b=second_num
  16.         record+=str(first_num)
  17.         i+=1
  18.     return record[b]
复制代码

评分

参与人数 1荣誉 +5 鱼币 +5 收起 理由
zltzlt + 5 + 5

查看全部评分

小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-2 00:13:16 From FishC Mobile | 显示全部楼层
一个代码题,我硬是弄成数学题
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-2 00:15:23 | 显示全部楼层
寻风 发表于 2020-3-2 00:10
def f(n):
    return ((9*n-1)*pow(10,n+1)+10)/81
   

输入96512好像有问题
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-2 00:24:48 | 显示全部楼层
  1. def fun340(n):
  2.     if n<=9:return n
  3.     count=0
  4.     num_length=0
  5.     while n>count:
  6.         count+=(num_length+1)*9*10**num_length
  7.         num_length+=1
  8.     count-=num_length*9*10**(num_length-1)
  9.     left_num,flag=n-count-1,True
  10.     record=''
  11.     i=1
  12.     while num_length>=i:
  13.         first_num,second_num=divmod(left_num,num_length*10**(num_length-i))
  14.         left_num=second_num
  15.         if flag:record+=str(first_num+1)
  16.         else:record+=str(first_num)
  17.         flag=False
  18.         i+=1
  19.     return record[left_num]
复制代码

或者写到一起
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-2 08:38:24 | 显示全部楼层
本帖最后由 kinkon 于 2020-3-2 16:59 编辑
  1. def p340(n):
  2.     if n < 10: return n
  3.     h, l = 9, 1
  4.     while n - h * l > 0:
  5.         n -= h * l
  6.         h *= 10
  7.         l += 1        
  8.     a, b = divmod(n, l)
  9.     if b:        
  10.         return str(10 ** (l - 1) + a)[b-1]
  11.     else:        
  12.         return str(10 ** (l - 1) + a - 1)[-1]
复制代码

评分

参与人数 1荣誉 +2 鱼币 +2 收起 理由
zltzlt + 2 + 2

查看全部评分

小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-2 10:03:05 | 显示全部楼层
  1. def solve(n:int):
  2.     if n<10:
  3.         return n
  4.     i=2
  5.     num=9
  6.     while n>num+9*(10**(i-1))*i:
  7.         num+=9*(10**(i-1))*i
  8.         i+=1
  9.     n-=num
  10.     if n%i==0:
  11.         return str(10**(i-1)+n//i-1)[-1]
  12.     m=str(10**(i-1)+n//i)
  13.     return m[n%i-1]
复制代码

评分

参与人数 1荣誉 +5 鱼币 +5 收起 理由
zltzlt + 5 + 5

查看全部评分

小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-2 11:46:55 | 显示全部楼层
晚了点
  1. n = input('n = ')
  2. str1 = ''
  3. for i in range(int(n) + 1):
  4.     str1 += str(i)
  5. print(str1[int(n)])
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-3-2 11:48:49 | 显示全部楼层

务必考虑一下效率
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-2 11:51:13 | 显示全部楼层
zltzlt 发表于 2020-3-2 11:48
务必考虑一下效率

耶,好像输入大数据会很慢。。。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-2 11:59:07 | 显示全部楼层
在测了吗?
9#
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-3-2 12:00:32 | 显示全部楼层
一个账号 发表于 2020-3-1 21:48
不知道列表推导式会不会更快一些

不会,很慢
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-2 13:01:02 | 显示全部楼层
kinkon 发表于 2020-3-2 08:38
下面程序说明:

怎么感觉和塔利班答案相像啊
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-2 13:45:50 | 显示全部楼层
fan1993423 发表于 2020-3-2 13:01
怎么感觉和塔利班答案相像啊

想不到好办法
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-2 14:06:16 From FishC Mobile | 显示全部楼层    本楼为最佳答案   
fan1993423 发表于 2020-3-2 00:15
输入96512好像有问题

多谢提醒,的确有bug,修改了一下

def f(n):
    return ((9*n-1)*(10**n)+10)/9
   
def get1(n,num):
    if f(n) > num :
        return n
    else:
        return get1(n+1,num)

def fun340():
    a = int(input())
    leve = get1(1,a)
    b = int(a - f(leve - 1))
    num = int(b/leve)
    l = int(leve-b%leve)

    m = pow(10,leve-1)+num
    end = int((m%pow(10,l))/pow(10,l-1))
    print(end)

评分

参与人数 1荣誉 +5 鱼币 +5 收起 理由
zltzlt + 5 + 5

查看全部评分

小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-2 14:14:07 | 显示全部楼层
def func340(n):
    count = 1
    i = 9
    temp = n-1
    j = 0
    while(temp >= 0):
        temp -= count*i
        i *= 10
        count += 1
    j = ((temp+1) + i//10*(count-1))%(count - 1)
    temp = (temp//(count-1) + i) - (i*8//9)
    return str(temp)[j-1]

评分

参与人数 1荣誉 +5 鱼币 +5 收起 理由
zltzlt + 5 + 5

查看全部评分

小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-3-2 15:56:13 | 显示全部楼层
kinkon 发表于 2020-3-1 20:51
暂时只想到这个方法,后续看看还有没有更好的,看看效率如何


输入 100000000 超出内存限制
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-2 15:56:22 | 显示全部楼层
  1. def fun340(n):
  2.     if n < 10:
  3.         return n
  4.     k = 1
  5.     # 先判断是k位数中的第n个
  6.     while n - k * 9 * (10 ** (k - 1)) > 0:
  7.         n -= k * 9 * (10 ** (k - 1))
  8.         k += 1
  9.     # 再根据位数计算出具体是哪个数字
  10.     num =10 ** (k - 1) + n // k
  11.     if n % k == 0:  # 整除的情况下为这个数的最后一位,而非是下一个数
  12.         num -= 1
  13.     # 最后判断是该数字的第几个数,并输出结果
  14.     index = n % k
  15.     return int(str(num)[index - 1])
复制代码

评分

参与人数 1荣誉 +5 鱼币 +5 收起 理由
zltzlt + 5 + 5

查看全部评分

小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-7-1 16:10

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表