1,在Python中将integer数转化为罗马数
说明:在罗马数中(3999以内),和阿拉伯数字相似,可以把它分解为个位,十位,百位,千位,然后相加(我是这么认为的+_+),所以这样就简单了,只需把不同位数的基数表示出来相加即可。
例如:
阿拉伯数字为124=100+20+4,
罗马数字为字符串相加‘CXXIV\’=‘C\’+‘XX\’+IV\’\’
按此规律见代码分析:
注意:4,9,40,90,400,900得用大的减小的表示(因为相同字符相连不超过三个)
def trans(n): Dict = {0:\'\',1:\'I\',5:\'V\',10:\'X\',50:\'L\',100:\'C\',500:\'D\',1000:\'M\'} #创建一个匹配字典,注意 0:‘\' 是小细节,帮助处理位系数为0的情况 num_str = str(n) s = \'\' for i in range(len(num_str)): #按位次循环相加 j = len(num_str)-1-i #字符是从左到右,10**j表示所在位次 num = int(num_str[i]) if num==0: # s +=\'\' else: N = num//5 #取整,用来判断是0+ 还是5+, 还是5-,还是10- M = num%5 #取余,用来判断相同相连的个数,1-3用加,4用减 if M==4: #,9,40,90,400,900的情况 s+=Dict[10**(j)]+Dict[(N+1)*5*10**(j)] #右减左 else: s+=Dict[N*5*10**(j)]+Dict[10**(j)]*M #左加右 return s
2,Python 给定一个整数,将其转为罗马数字
输入确保在 1 到 3999 的范围内
def change(text): num=int(text) # 数组内数据位置不要改,不然就不能从高位开始对比 checkNum = [1000, 900, 500, 400, 100, 90, 50, 40, 10, 9, 5, 4, 1] str =[\"M\", \"CM\", \"D\", \"CD\", \"C\", \"XC\", \"L\", \"XL\", \"X\", \"IX\",\"V\", \"IV\", \"I\"] roman = \"\" i = 0 #对比完,减去已对比数组,对比数组下个值 while (num != 0) : if (num >= checkNum[i]): num -= checkNum[i] roman += str[i] else: i+=1 return roman def main(): text = input(\"输入整数\") print(change(text)) main()
以上为个人经验,希望能给大家一个参考,也希望大家多多支持。
© 版权声明
THE END
暂无评论内容