C++如何将罗马数字转化成整数


这篇文章主要介绍“C++如何将罗马数字转化成整数”,在日常操作中,相信很多人在C++如何将罗马数字转化成整数问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”C++如何将罗马数字转化成整数”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!Roman numerals are represented by seven different symbols:I,V,X,L,C,DandM.Symbol Value
I 1
V 5
X 10
L 50
C 100
D 500
M 1000For example,two is written asIIin Roman numeral, just two one”s added together. Twelve is written as,XII, which is simplyX+II. The number twenty seven is written asXXVII, which isXX+V+II.Roman numerals are usually written largest to smallest from left to right. However, the numeral for four is notIIII. Instead, the number four is written asIV. Because the one is before the five we subtract it making four. The same principle applies to the number nine, which is written asIX. There are six instances where subtraction is used:Ican be placed beforeV(5) andX(10) to make 4 免费云主机域名and 9.Xcan be placed beforeL(50) andC(100) to make 40 and 90.Ccan be placed beforeD(500) andM(1000) to make 400 and 900.Given a roman numeral, convert it to an integer. Input is guaranteed to be within the range from 1 to 3999.Example 1:Input:”III”
Output: 3Example 2:Input:”IV”
Output: 4Example 3:Input:”IX”
Output: 9Example 4:Input:”LVIII”
Output: 58
Explanation: L = 50, V= 5, III = 3.Example 5:Input:”MCMXCIV”
Output: 1994
Explanation: M = 1000, CM = 900, XC = 90 and IV = 4.罗马数转化成数字问题,我们需要对于罗马数字很熟悉才能完成转换。以下截自百度百科:罗马数字是最早的数字表示方式,比阿拉伯数字早2000多年,起源于罗马。如今我们最常见的罗马数字就是钟表的表盘符号:Ⅰ,Ⅱ,Ⅲ,Ⅳ(IIII),Ⅴ,Ⅵ,Ⅶ,Ⅷ,Ⅸ,Ⅹ,Ⅺ,Ⅻ……对应阿拉伯数字(就是现在国际通用的数字),就是1,2,3,4,5,6,7,8,9,10,11,12。(注:阿拉伯数字其实是古代印度人发明的,后来由阿拉伯人传入欧洲,被欧洲人误称为阿拉伯数字。)I – 1V – 5X – 10L – 50C – 100D – 500M – 10001、相同的数字连写,所表示的数等于这些数字相加得到的数,如:Ⅲ = 3;2、小的数字在大的数字的右边,所表示的数等于这些数字相加得到的数, 如:Ⅷ = 8;Ⅻ = 12;3、小的数字,(限于Ⅰ、X 和C)在大的数字的左边,所表示的数等于大数减小数得到的数,如:Ⅳ= 4;Ⅸ= 9;4、正常使用时,连写的数字重复不得超过三次。(表盘上的四点钟“IIII”例外)5、在一个数的上面画一条横线,表示这个数扩大1000倍。有几条须注意掌握:1、基本数字Ⅰ、X 、C 中的任何一个,自身连用构成数目,或者放在大数的右边连用构成数目,都不能超过三个;放在大数的左边只能用一个。2、不能把基本数字V 、L 、D 中的任何一个作为小数放在大数的左边采用相减的方法构成数目;放在大数的右边采用相加的方式构成数目,只能使用一个。3、V 和X 左边的小数字只能用Ⅰ。4、L 和C 左边的小数字只能用X。5、D 和M 左边的小数字只能用C。而这道题好就好在没有让我们来验证输入字符串是不是罗马数字,这样省掉不少功夫。需要用到 HashMap 数据结构,来将罗马数字的字母转化为对应的整数值,因为输入的一定是罗马数字,那么只要考虑两种情况即可:第一,如果当前数字是最后一个数字,或者之后的数字比它小的话,则加上当前数字。第二,其他情况则减去这个数字。解法一:我们也可以每次跟前面的数字比较,如果小于等于前面的数字,先加上当前的数字,比如 “VI”,第二个字母 “I” 小于第一个字母 “V”,所以要加1。如果大于的前面的数字,加上当前的数字减去二倍前面的数字,这样可以把在上一个循环多加数减掉,比如 “IX”,我们在 i=0 时,加上了第一个字母 “I” 的值,此时结果 res 为1。当 i=1 时,字母 “X” 大于前一个字母 “I”,这说明前面的1是要减去的,而由于前一步不但没减,还多加了个1,所以此时要减去2倍的1,就是减2,所以才能得到9,整个过程是 res = 1 + 10 – 2 = 9,参见代码如下:解法二:到此,关于“C++如何将罗马数字转化成整数”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注百云主机网站,小编会继续努力为大家带来更多实用的文章!

相关推荐: Python第三方库管理Pip和Conda怎么用

本文小编为大家详细介绍“Python第三方库管理Pip和Conda怎么用”,内容详细,步骤清晰,细节处理妥当,希望这篇“Python第三方库管理Pip和Conda怎么用”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。1、Anacond…

免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。

(0)
打赏 微信扫一扫 微信扫一扫
上一篇 02/12 15:11
下一篇 02/12 15:11

相关推荐