本文实例讲述了Python3.5实现的罗马数字转换成整数功能。分享给大家供大家参考,具体如下
本文实例讲述了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。
以下是详细代码:
# -*- 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)
测试运行结果:
如有更好更简洁的想法,请留言
Python3.5 罗马数字 转换 整数