罗马数字转换python_Python练习【3】【罗马数字转换/查
题目1:罗马数字转换
罗马数字包含以下七种字符: I, V, X, L,C,D 和 M
字符 数值
I 1
V 5
X 10
L 50
C 100
D 500
M 1000例如,罗马数字2写做 II,即为两个并排放置的的 1,12写做XII,即为 X + II ,27写做XXVII,即为XX+V+II
在罗马数字中,小的数字在大的数字的右边。但 4 不写作 IIII,而是 IV。数字 1 在数字 5 的左边,所表示的数等于大数减小数得到的数值 4 。同样地,数字 9 表示为 IX。这个规则只适用于以下六种情况:
I 可以放在 V (5) 和 X (10) 的左边,来表示 4 和 9
X 可以放在 L (50) 和 C (100) 的左边,来表示 40 和 90
C 可以放在 D (500) 和 M (1000) 的左边,来表示 400 和 900
给定一个罗马数字,将其转换成整数。输入确保在 1 到 3999 范围内
示例:
示例 1:
输入: “III”
输出: 3
示例 2:
输入: “IV”
输出: 4
示例 3:
输入: “IX”
输出: 9
示例 4:
输入: “LVIII”
输出: 58
解释: C = 100, L = 50, XXX = 30 and III = 3.
示例 5:
输入: “MCMXCIV”
输出: 1994
解释: M = 1000, CM = 900, XC = 90 and IV = 4.编程思路:
罗马数字一般来说小数在大数后面,各数字译成对应十进制相加即可
若小数在大数前面,则取对应的小数的相反数相加即可
例:
IV=-1+5=4
CM=-100+1000=900:
MCMXCIV=1000-100+1000-10+100-1+5=1994代码:
罗马数字转十进制数函数:
def roman_into_decimal(roman_num): ##罗马数字转十进制数函数 for i in roman_num: if i not in roman: print('请输入正确的罗马数字') return ## 遍历输入字符串,判断是否为正确的罗马数字,不是则提示并返回None num = 0 reduce = [roman_num[i] for i in range(len(roman_num) - 1) if roman[roman_num[i]] < roman[roman_num[i + 1]]] ## 判断逆序的组合,并将逆序的首字母存入列表reduce for i in roman_num: num += (-roman[reduce.pop(reduce.index(i))]) if i in reduce else roman[i] ## 遍历输入的字符串,如果reduce中包含对应key值,则从reduce中弹出(去重)并减去对应value值 if 1<=num<=3999: print('对应十进制数:', num) ## 输出对应10进制数 else: print('超出范围,请输入转换值在1-3999之间的数')
主程序:roman = dict(I=1, V=5, X=10, L=50, C=100, D=500, M=1000) ## 定义基本罗马数字
while True:
roman_in = input('请输入转换值在1-3999之间的罗马数字:')
roman_into_decimal(roman_in) ##调用函数测试结果:题目2:公共前缀
编写一个函数来查找字符串数组中的最长公共前缀
如果不存在最长公共前缀,返回空字符串 ''说明:所有输入只包含小写字母 a-z
示例 1:
输入: [“flower”,”flow”,”flight”]
输出: “fl”
示例 2:
输入: [“dog”,”racecar”,”car”]
输出: “”
解释: 输入不存在最长公共前缀代码:
寻找公共前缀函数:
def find_public_pro(string): ##寻找公共前缀函数 public_pro='' ##定义空字符串用于接收公共字符 for i in range(min([len(i) for i in string])): ##循环次数最长为最短字符串长度 for j in range(len(string)-1): if string[j][i]!=string[j+1][i]: return public_pro ##从首字母开始所有字符串同一位置出现字符不相等时返回public_pro else: public_pro=public_pro+string[0][i] ##从首字母开始所有字符串同一位置字符相等时,将该字符放入public_pro else: return public_pro ##for循环完毕说明最短字符串即为公共前缀,返回公共前缀
主程序:while True: ##死循环
try:
string_in=input('请输入字符串数组(仅包含小写字母):\n例:["flower","flow","flight"]').replace('"','').strip('[').strip(']').replace(',',' ')
##以规定格式输入时,去除字符串中无用的[]",等字符
if not string_in.replace(' ','').islower():
print('请输入正确的字符串数组(仅包含小写字母)')
continue
##如果字符串不是纯小写字母,提示并刷新
string_in=string_in.split(' ') ##以空格分隔字符串为列表
print(find_public_pro(string_in))
except Exception as e:
print('程序异常')
##程序异常提示,捕获程序退出相关以外的所有异常
finally:
if bool(input('按下Enter键继续')):
pass
##无论是否异常,都通过键盘暂停,防止页面刷新以便观察结果测试结果:
python3中默认汉字属于字母类,但其中壹/一等字属于数字
罗马数字转换python_Python练习【3】【罗马数字转换/查相关推荐
- 时间转换python_Python 日期与时间转换的方法
问题 你需要执行简单的时间转换,比如天到秒,小时到分钟等的转换. 解决方案 为了执行不同时间单位的转换和计算,请使用 datetime 模块. 比如,为了表示一个时间段,可以创建一个 timedelt ...
- Windows环境下Unicode编程总结和将ANSI转换到Unicode 将Unicode转换到ANSI
Windows环境下Unicode编程总结 UNICODE环境设置 在安装Visual Studio时,在选择VC++时需要加入unicode选项,保证相关的库文件可以拷贝到system32下. UN ...
- python数据逆透视_PIVOT(透视转换)和UNPIVOT(逆透视转换)
一.原数据状态 二.手动写透视转换1 三.手动写透视转换2 四.PIVOT(透视转换)和UNPIVOT(逆透视转换)详细使用 使用标准SQL进行透视转换和逆视转换 --行列转换 create tabl ...
- ORA-22835 缓冲区对于 CLOB 到 CHAR 转换或 BLOB 到 RAW 转换而言太小
前言 做项目的时候遇到一个报错:ORA-22835 缓冲区对于 CLOB 到 CHAR 转换或 BLOB 到 RAW 转换而言太小.查找原因发现是某个字段在数据库中是clob类型.然后sql语句进行查 ...
- oracle clob raw 转换,ORA-22835 缓冲区对于 CLOB 到 CHAR 转换或 BLOB 到 RAW 转换而言太小...
前言 做项目的时候遇到一个报错:ORA-22835 缓冲区对于 CLOB 到 CHAR 转换或 BLOB 到 RAW 转换而言太小.查找原因发现是某个字段在数据库中是clob类型.然后sql语句进行查 ...
- json字符串转换成json对象,json对象转换成字符串,值转换成字符串,字符串转成值...
json字符串转换成json对象,json对象转换成字符串,值转换成字符串,字符串转成值 原文:json字符串转换成json对象,json对象转换成字符串,值转换成字符串,字符串转成值 主要内容: 一 ...
- 【PC工具】在线格式转换工具,视频格式转换,视频转gif工具
上次在社区发文章,得知文章编辑器终于支持gif格式的动图了,但得到gif的动图需要将mp4格式的视频进行格式转换,于是便找到了这个在线工具.这年头方便好用是第一位的,功能差不多的情况下在线工具优于绿色 ...
- ITK:向转换工厂注册非默认转换
ITK:向转换工厂注册非默认转换 内容提要 C++实现代码 内容提要 向转换工厂注册非默认转换 C++实现代码 #include "itkTransformFileReader.h" ...
- 金额转换,阿拉伯数字的金额转换成中国传统的形式如:(¥1011)-(一千零一拾一元整)输出。...
程序代码如下: package cn.itcast.framework.interview;import java.text.NumberFormat; import java.util.HashMa ...
- c语言全角半角转换函数,全角半角转换函数(示例代码)
--(此函数部分思路参考了CSDN上大力的转换函数)--邹建2005.01(引用请保留此信息)--*/ Go --创建函数 create functionSBC2DBC (@str nvarchar( ...
最新文章
- POJ 3237.Tree -树链剖分(边权)(边值更新、路径边权最值、区间标记)贴个板子备忘...
- 锋利的JQuery学习笔记01
- Android之Animation动画的介绍及用法
- 无人出租车被警察截停后逃逸!AI:我当时害怕极了
- 做产品经理的第1年、第5年和第10年...
- 十二岁孩子学编程用c语言好吗,太原12岁学编程
- 发送邮件现在应用得最多的两种情况就是利用.NET自带的发送邮件和利用jmail组件来发送邮件。...
- 如何设置ftp服务器上传文件夹至不同路径,设置ftp服务器上传文件夹
- 鸿蒙os系统越来越少了,鸿蒙系统怎么它的消息越来越少了?是不是不会上线手机了?...
- java 查找引用_java – Eclipse查找方法的引用
- 读书笔记∣疯狂XML讲义
- iOS阶段学习第31天笔记(UINavigationBar介绍)
- linux系统怎么修改数据库密码,Linux系统修改数据库密码相关
- eslint 如何关闭检查变量名规范或者大小写检查
- 利用python对资产收益率进行正态检验
- 超越Nest:集智能温控和家庭控制的Cosy
- [转]window xp IIS的配置(1)
- 云服务器如何共享文件夹,云服务器如何设置共享文件夹
- 文明与征服阵容搭配,文明与征服阵容推荐
- 字符串集合中相互包含关系算法
热门文章
- LaTeX公式符号总结(Markdown适用)
- 【知识兔】Excel教程之隔行/隔列求和
- 解决iphone的短信中心号码设置错误的方案
- PAT 乙级练习 1068 万绿丛中一点红 - 超级详细的思路讲解
- 从敏思博客的倒闭事件看历史重现... 1
- 四川大学计算机专业调剂,四川大学计算机学院(软件学院)2019考研调剂信息
- SAP S4 库存管理 技术分享
- 个人财务流水账系统c语言,微易个人财务收支管理系统的教程
- 惊叹!前NASA员工绘大型精美地面立体画(高清组图)
- 如何往 Apple Watch 中添加音乐