鱼C论坛

 找回密码
 立即注册
查看: 2036|回复: 2

[技术交流] 鱼C论坛Python精英挑战赛(02期)比赛结果

[复制链接]
发表于 2017-6-23 13:18:09 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本期的挑战赛由于题目相对比较简单,所有参赛的鱼油基本都计算出了正确的结果,为了比赛的公平性,本次挑战赛主要从准确率、计算效率、代码简洁度这3个维度综合考量。

比赛结果如下:
无标题.png

综合比分是版主@冬雪雪冬 获胜,但是为了鼓励新人参加,本次挑战赛从参加的新人选手中产生,所以顺延到第二名WelanceLee获胜!

不过这次大家的代码都很不错,执行效率方面都是毫秒级的。

本帖被以下淘专辑推荐:

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

使用道具 举报

 楼主| 发表于 2017-6-23 13:23:54 | 显示全部楼层
我的解答:4行代码版本
  1. def Calc(rawdata, newdata):
  2.     trans = dict(zip('0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz',range(62)))
  3.     trans2int = lambda s, m: sum([trans[s[i]]*(m**(len(s)-i-1)) for i in range(len(s))])
  4.     return [(i,j) for i in range(trans[max(rawdata)]+1,63) for j in range(trans[max(newdata)]+1,63) if trans2int(rawdata, i) == trans2int(newdata, j)][0]
复制代码

5行代码版本(用生成器优化了执行效率):
  1. def Calc(rawdata, newdata):
  2.     trans = dict(zip('0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz',range(62)))
  3.     trans2int = lambda s, m: sum([trans[s[i]]*(m**(len(s)-i-1)) for i in range(len(s))])
  4.     for each in ((i,j) for i in range(trans[max(rawdata)]+1,63) for j in range(trans[max(newdata)]+1,63) if trans2int(rawdata, i) == trans2int(newdata, j)):
  5.         return each
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-6-23 15:34:25 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-4-27 12:05

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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