加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

Project Euler:Problem 89 Roman numerals

发布时间:2020-12-14 01:10:44 所属栏目:百科 来源:网络整理
导读:For a number written in Roman numerals to be considered valid there are basic rules which must be followed. Even though the rules allow some numbers to be expressed in more than one way there is always a "best" way of writing a particular

For a number written in Roman numerals to be considered valid there are basic rules which must be followed. Even though the rules allow some numbers to be expressed in more than one way there is always a "best" way of writing a particular number.

For example,it would appear that there are at least six ways of writing the number sixteen:

IIIIIIIIIIIIIIII
VIIIIIIIIIII
VVIIIIII
XIIIIII
VVVI
XVI

However,according to the rules onlyXIIIIIIandXVIare valid,and the last example is considered to be the most efficient,as it uses the least number of numerals.

The 11K text file,roman.txt(right click and 'Save Link/Target As...'),contains one thousand numbers written in valid,but not necessarily minimal,Roman numerals; seeAbout... Roman Numeralsfor the definitive rules for this problem.

Find the number of characters saved by writing each of these in their minimal form.

Note: You can assume that all the Roman numerals in the file contain no more than four consecutive identical units.



化简成最简格式无非就是遇到DCCCC变成CM,LXXXX变成XC,VIIII变成IX,IIII变成IV,XXXX变成XL,CCCC变成CD

反正遇到这样的这些字符最后都变成2个字符


import re

ans=0
for line in open("roman.txt"):
    a=len(line)
    line=re.sub('DCCCC|LXXXX|VIIII|CCCC|XXXX|IIII','aa',line)
    b=len(line)
    ans=ans+a-b

print(ans)

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读