本文实例讲述了python3.5实现的罗马数字转换成整数功能。分享给大家供大家参考,具体如下:
问题概述:
给定一个罗马数字 ,将罗马数字转换成整数。
如罗马数字i,ii,iii,iv,v分别代表数字 1, 2, 3, 4, 51,2,3,4,5。
首先要来了解一下罗马数字表示法,基本字符有 7 个:i、v、x、l、c、d、m,分别表示 1、5、10、50、100、500、1000。
在构成数字的时候,有下列规则:
1、相同的数字连写,所表示的数等于这些数字相加得到的数,如:iii = 3;
2、小的数字在大的数字的右边,所表示的数等于这些数字相加得到的数, 如:viii = 8;xii = 12;
3、小的数字,(限于ⅰ、x和c)在大的数字的左边,所表示的数等于大数减小数得到的数,如:iv = 4;ix = 9;
4、正常使用时,连写的数字重复不得超过三次。
输入格式
输入一个罗马数字字符串,其对应的数字为 s (1≤s≤3999)。
输出格式
输出对应的整数 s。
以下是详细代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
# -*- coding:utf-8 -*-
#! python3
chart = { 'i' : 1 , 'v' : 5 , 'x' : 10 , 'l' : 50 , 'c' : 100 , 'd' : 500 , 'm' : 1000 }
strs = input ()
result = 0
omit = - 1 # omit为需省略的字符位
if strs in chart:
print (chart[strs])
else :
for i in range ( len (strs)): # 遍历字符串的每一位:(0,len-1)
if i = = omit: # 如果无需省略i
pass
elif i < = len (strs) - 2 : # 如果还没有遍历到最后一位:(len-1-1)
if chart[strs[i]] < chart[strs[i + 1 ]]: # 如果前一位对应值小于后一位的
result + = chart[strs[i + 1 ]] - chart[strs[i]] # 进行减操作
omit = i + 1 # 省略下一位字符
else :
result + = chart[strs[i]]
else : # 遍历到最后一位
result + = chart[strs[i]]
print (result)
|
测试运行结果:
如有更好更简洁的想法,请留言
希望本文所述对大家python程序设计有所帮助。
原文链接:https://blog.csdn.net/weixin_39406894/article/details/80468036