摘要:罗马数字转换成阿拉伯数字给出一个罗马数字字符串,返回此数字的阿拉伯数字思路存储单个罗马字母代表的阿拉伯数字初始状态,循环遍历字符串,如果所代表的阿拉伯数字大于的,则加到上,如果小于,则减去代表的阿拉伯数字代码右边界保证不会下标越界本
罗马数字转换成阿拉伯数字 Roman to integer
给出一个罗马数字(字符串),返回此数字的阿拉伯数字(int)
Given a roman numeral, convert it to an integer.
Input is guaranteed to be within the range from 1 to 3999.
example 1
input: CCCLXXXIX output: 389思路
dict存储单个罗马字母代表的阿拉伯数字
初始状态sum = 0,循环遍历字符串,如果 s[i]所代表的阿拉伯数字大于s[i+1]的,则加到sum上,如果小于,则sum减去s[i]代表的阿拉伯数字
代码class Solution(object): def romanToInt(self, s): """ :type s: str :rtype: int """ a = {"M": 1000, "D": 500, "C": 100, "L": 50, "X": 10, "V": 5, "I": 1} sum = 0 for i in range(len(s) - 1): #range右边界len(s) - 1 保证 i + 1不会下标越界 if a[s[i]] < a[s[i+1]]: sum -= a[s[i]] else: sum += a[s[i]] return sum + a[s[len(s) - 1]]
本题以及其它leetcode题目代码github地址: github地址
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/38671.html
摘要:下面分几步来简单的探探不同类型的转换吧以下的内容,都可以从权威指南中找到。其他值转换成在编写代码的过程中,几乎不用考虑它的取值类型。核心内置类,会尝试先于可以理解为对象优先转换成数字例外的是,利用的是转换。 最近在写公司的登录注册模块,遇到类型不同相比较的时候,就心惊胆战,每次都要用浏览器来验证一下,决定乱七八糟的随便写一下,方便日后自己回顾知识~ 弱类型带来的那些让人迷糊的事 弱类型...
摘要:阿拉伯数字转换成罗马数字给出一个阿拉伯数字,返回此数字的罗马数字表示思路用表记录关键的罗马数字和阿拉伯数字,将输入循环除以,,这些关键数字,余数为,将对应的罗马字符串加次看到大神的思路,也是查表,但更加精妙,将数字分解为千位,百位,十位和个 阿拉伯数字转换成罗马数字 Integer to Roman 给出一个阿拉伯数字,返回此数字的罗马数字表示 Given an integer, c...
摘要:核心内置类,会尝试先于可以理解为对象优先转换成数字例外的是,利用的是转换。非核心的对象,通过自己的实现中定义的方法转换成原始值。 本文首发于个人博客 showImg(https://segmentfault.com/img/remote/1460000015954811?w=639&h=724); 看到这个是不是有一种想打人的感觉,垃圾 JavaScript,这特么都什么鬼,相信很多...
阅读 1372·2021-09-13 10:25
阅读 557·2019-08-30 15:53
阅读 2272·2019-08-30 15:44
阅读 2032·2019-08-29 17:20
阅读 1597·2019-08-29 16:36
阅读 1797·2019-08-29 14:10
阅读 1788·2019-08-29 12:44
阅读 1171·2019-08-23 14:13