Euler项目问题17 Python

2024-04-26 20:29:18 发布

您现在位置:Python中文网/ 问答频道 /正文

请告诉我如何修复此代码。我试过纠正很多事情,但我有10个额外的解决方案!

如果数字1到5是用单词写出来的:1,2,3,4,5,那么总共有3+3+5+4+4=19个字母。

如果所有从1到1000(一千)的数字都是用文字写出来的,会用多少个字母?

注意:不要计算空格或连字符。例如,342(三百四十二)包含23个字母,115(一百一十五)包含20个字母。写数字时使用“and”符合英国用法。

我的解决方案

sd={0:0,1: 3, 2: 3, 3: 5, 4: 4, 5: 4, 6: 3, 7: 5, 8: 5, 9: 4}
dd1={10:3,11:6,12:6,13:8,14:8,15:7,16:7,17:9,18:9,19:8}
dd2={2:6,3:6,4:5,5:5,6:5,7:7,8:6,9:6}
td= {0: 10, 1: 13, 2: 13, 3: 15, 4: 14, 5: 14, 6: 13, 7: 15, 8: 15, 9: 14}
cd={0:0,1: 3, 2: 3, 3: 5, 4: 4, 5: 4, 6: 3, 7: 5, 8: 5, 9:    4,10:3,11:6,12:6,13:8,14:8,15:7,16:7,17:9,18:9,19:8}


def cw(n) :

  if n/10 == 0 :               # If the number is less than 10 execute this section                               
   return sd[n%10]

       elif n/100 == 0 :           # If the number is less than 100 execute this section
   if n<20 :
    return(dd1[n])         # Directly map to dd1 
   else :
    return(dd2[n/10]+sd[n%10])  # If the number is > 20 do a construction 
  elif n/1000==0 :               
   if n%100==0:
    return sd[n/100] + 7        # If the number is multiples of 100 give assuming single digit and 7 for hundred 
   elif n%100 < 20 :
    return td[n/100] + cd[n%100]  # If 3 digit numbers not more than *20 , then direct mapping 
   else :
    return td[n/100] + dd2[(n%100)/10] + sd[n%10]

count = 0 
for i in range(1,1000) : 
 count = count + cw(i)
print count + 11

我得到21134,答案是。。。(扰流器:请将鼠标悬停在下一行上查看)

21124

很烦人!


Tags: thenumberreturnifiscount字母数字
2条回答

好吧,你给的密码太多神秘数字了。正如另一张海报所建议的那样,你最好让电脑把数字单词表中各种单词的长度汇总起来。一个观点:如前所述,除了这个项目Euler问题之外,你的代码没有任何我能想象得到的有用之处。我采用的方法是编写一个函数“num2words(I)”,该函数给定一个整数I,返回I的单词。然后主循环将数字1到1000中的每一个转换为单词,并对单词的长度进行求和,使用正则表达式从计数中排除空格,只计算字母。性能是可以接受的,我断言我的方法也更容易调试。虽然目前我在其他地方对num2words没有迫切的需求,但我至少可以想象有一天能够重用这些代码,也许是在支票打印程序中。

顺便说一句,我的num2words例程递归地使用自己,方法是断开大数字(例如k ddd)的前导数字,并计算num2words(k)+“000”,如果剩余的数字不是零,则标记“+”+num2words(ddd)。处理数百个的代码是类似的。为数百万人添加代码是很直接的。

说到神秘数字,为什么你的主循环会停在999,然后将最后的总数调整为11来计算“一千”中的字母?假设有人被要求把你的程序转换成用另一种语言处理数字。他们有多大的机会在最后得到+11所需的调整?

在我看来,如果你解决欧拉计划问题的目的只是为了得到正确的答案,那么你就错过了解决问题的教育价值。目的开发良好的干净代码。即使在你的代码产生了正确的答案之后,坐下来重新阅读你的代码,并试图使它变得更好(例如,更容易阅读,更“Python”,你会自豪地向程序员朋友展示这一点)。

“十八”字只有八个字母,没有九个。因为它在1-1000范围内出现了10次,这就解释了这种差异。

顺便说一下,如果您要检查n是否小于10,为什么不直接使用n<10而不是n/10 == 0

相关问题 更多 >