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 simply 香港云主机X+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++如何实现罗马数字转化成整数”的内容了,经过本文的学习后,相信大家对C++如何实现罗马数字转化成整数这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是开发云,小编将为大家推送更多相关知识点的文章,欢迎关注!

相关推荐: js中的树怎么理解

本篇内容介绍了“js中的树怎么理解”的有关 香港云主机知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1、分层数据的抽象模型。2、前端工作中常见的树包括:DOM树、级联选…

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

(0)
打赏 微信扫一扫 微信扫一扫
上一篇 07/14 15:46
下一篇 07/14 15:47

相关推荐