鱼C论坛

 找回密码
 立即注册
12
返回列表 发新帖
楼主: zltzlt

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

[复制链接]
发表于 2020-3-31 15:02:43 | 显示全部楼层
看蒙了。。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-3-31 17:20:23 | 显示全部楼层
塔利班 发表于 2020-3-30 20:46
头大,写个超时的

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-4-1 13:20:04 | 显示全部楼层
塔利班 发表于 2020-3-30 20:46
头大,写个超时的

输入 n = 2, k = 4 超时
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-4-1 13:20:24 | 显示全部楼层
TJBEST 发表于 2020-3-30 22:12
@zltzlt  k不会超过10吧

是的
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-4-1 13:21:56 | 显示全部楼层

输入 n = 1,k = 1 超时
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-1 13:50:44 | 显示全部楼层    本楼为最佳答案   
@zltzlt  已经补充
  1. def oldfun363(n,k):
  2.     if n == 1:
  3.         result = ''
  4.         for each in range(0,k):
  5.             result += str(each)
  6.         return result
  7.     result = '0'*(n-1)
  8.     hasBeenIn = set()
  9.     temp = 0
  10.     M = k**n
  11.     for each in range(0,M):
  12.         for inner in range(k-1,-1,-1):
  13.             tempInner = (temp*k+inner)%(M)
  14.             if tempInner not in hasBeenIn:
  15.                 hasBeenIn.add(tempInner)
  16.                 result += str(inner)
  17.                 temp = tempInner
  18.                 break
  19.     return result
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-5-25 10:32

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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