首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >我的Euler Practice代码有没有更干净的Python版本

我的Euler Practice代码有没有更干净的Python版本
EN

Stack Overflow用户
提问于 2018-08-04 08:04:40
回答 1查看 58关注 0票数 -1

如果我们列出10以下的所有自然数,它们是3或5的倍数,我们得到3,5,6和9,这些倍数的总和是23。

找出1000以下3或5的所有倍数的总和。我的Python代码工作正常,我想知道它是否可以改进或缩短?

代码语言:javascript
复制
  x = []
     y = []
     z = []
n = int(input())
for i in range(1, n+1):
    if i%3 == 0:
        x.append(i)
        r = sum (x)
for j in range(1, n+1):
    if j%5 == 0:
        y.append(j)
        s = sum(y)
for m in range(1, n+1):
    if m%3 == 0 and m%5 == 0:
        z.append(m)
        t = sum(z)


print((r+s)-t)
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-08-04 08:26:29

我不知道这是否被认为是更干净的,但为了解决前面的评论,我认为这是你的一行解决方案:

代码语言:javascript
复制
n = int(input())
print((sum(list(range(0, n, 3)))+sum(list(range(0, n, 5))))-sum(list(range(0, n, 15))))
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/51681359

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档