鱼C论坛

 找回密码
 立即注册
查看: 1860|回复: 0

[技术交流] 【每天进步一点点】Python解题笔记(04篇)

[复制链接]
发表于 2017-8-21 13:41:27 | 显示全部楼层 |阅读模式

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

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

x
今天再多更新一篇,弥补一下周末两天偷懒了

再来看“欧拉计划”的第4题:找出由2个3位数构成的最大回文数。

先来看回文数,就是顺着看和倒着看都相同的数。

那么想当然的就可以写成:
def is_cycle(n):
    return str(n)==str(n)[::-1]

程序逻辑当然是没问题,但是要知道数字和字符串的转化需要进行一定量的运算,当数字量非常大的话,这个转化带来的运算量也就非常可观。
比较理想的方法是直接用数字进行运算,这样处理速度可以快很多。
def cycle(n):
        t = 0
        while n>0:
                t = t*10+n%10
                n //= 10
        return t

当然,对于本题这种小规模的运算量,其实速度差别就不是很明显了。

然后再看题目,要求2个3位数构成的最大的回文数,那这个回文必然是一个6位数。如果其以9开头的话,可以构成由2个数的乘积的话,只有1*9和3*3.
而这2个3位数也必然是9开头。
for i in range(10):
        for j in range(10):
                if (900+i*10+1)*(900+j*10+9) == cycle((900+i*10+1)*(900+j*10+9)):
                        print(900+i*10+1,900+j*10+9,(900+i*10+1)*(900+j*10+9))
                        exit()
                if (900+i*10+3)*(900+j*10+3) == cycle((900+i*10+3)*(900+j*10+3)):
                        print(900+i*10+3,900+j*10+3,(900+i*10+3)*(900+j*10+3))
                        exit()
如果找不到,那就需要继续往下找8开头的6位数,可以构成8的乘积,只有1*8和2*4,用的方法类似,就不再重复了。

对于本题来说,直接找9开头的就已经能得出结论了,所以就不必要再找其他数了。

最后写一个一行代码输出的:
print(max((i*j for i in range(999,100,-1) for j in range(999,i+1,-1) if str(i*j) == str(i*j)[::-1])))

本帖被以下淘专辑推荐:

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-24 11:49

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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