罗马数字转整数的golang实现
罗马数字包含以下七种字符: I, V, X, L,C,D 和 M。
字符 数值
I
V
X
L
C
D
M
例如, 罗马数字 2 写做 II ,即为两个并列的 1。12 写做 XII ,即为 X + II 。 27 写做 XXVII, 即为 XX + V + II 。
通常情况下,罗马数字中小的数字在大的数字的右边。但也存在特例,例如 4 不写做 IIII,而是 IV。数字 1 在数字 5 的左边,所表示的数等于大数 5 减小数 1 得到的数值 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 的范围内。
输入: "III"
输出:
输入: "IV"
输出:
输入: "IX"
输出:
输入: "LVIII"
输出:
解释: L = , V= , III = .
输入: "MCMXCIV"
输出:
解释: M = , CM = , XC = , IV = .
按照题意,其实就是算出各个罗马数字,然后进行相加。但是这个罗马数字有可能是1个字符代表一个数字,也有可能两个字符代表一个数字,所以我就用了两个map来记录下这两种不同的情况
specialRomanStringMap := map[string]int{"IV": , "IX": , "XL": , "XC": , "CD": , "CM": }//特殊罗马数字
romanStringMap := map[string]int{"I": , "V": , "X": , "L": , "C": , "D": , "M": }//正常罗马数字
- 然后我们就要对给定的字符串去取字符
- 但是当我们取到一个字符的时候,我们还得再取一个字符,用两个字符去特殊的map去查找是否存在
- 当存在的时候我们就记录下值
- 当没有的时候,我们就用第一个字符去正常的罗马数字map中找,并记录下值
整体代码:
func romanToInt(s string) int {
specialRomanStringMap := map[string]int{"IV": , "IX": , "XL": , "XC": , "CD": , "CM": } //特殊罗马数字
romanStringMap := map[string]int{"I": , "V": , "X": , "L": , "C": , "D": , "M": } //正常罗马数字
result :=
for len(s) != { //对字符串循环
if len(s) > { //当长度大于1的时候,才有必要去特殊罗马数字map中查找
chars := s[:] //首先我们得拿出两个字符去特殊的map中查找
if v, ok := specialRomanStringMap[chars]; ok { //当存在的时候记录值
result += v
s = s[:]
} else { //不存在的时候去正常map中查找,并记录
result += romanStringMap[string(s[])]
s = s[:]
}
} else { //当字符串的长度小于等于1的就只能去正常的罗马数字map中查找
result += romanStringMap[string(s[])]
s = s[:]
}
}
return result
}
还有另外种思路,请仔细看下面三个说明:
- I 可以放在 V (5) 和 X (10) 的左边,来表示 4 和 9。
- X 可以放在 L (50) 和 C (100) 的左边,来表示 40 和 90。
- C 可以放在 D (500) 和 M (1000) 的左边,来表示 400 和 900。
举个例子
- 当输入是IV,那就是4,当输入是VI,那就是6
- 当输入是IX,那就是9,当输入是XI,那就是11
- 当输入是XL,那就是40,当输入是LX,那就是60
- 当输入是XC,那就是90,当输入是CX,那就是110
- 当输入是CD,那就是400,当输入是DC,那就是600
- 当输入是CM,那就是900,当输入是MC,那就是1100
可以看出来有一个规律:右加左减
按照这个规律,那就可以从字符串的右边开始处理
func romanToInt1(s string) int {
res :=
m := map[byte]int{
'I': ,
'V': ,
'X': ,
'L': ,
'C': ,
'D': ,
'M': ,
}
last :=
for i := len(s) - ; i >= ; i-- {
temp := m[s[i]]//拿到最后一位
sign := //用于标记是减还是加
if temp < last {
//小数在大数的左边,要减去小数
sign = -
}
res += sign * temp
last = temp
}
return res
}
罗马数字转整数的golang实现的更多相关文章
- C#版 - Leetcode 13. 罗马数字转整数 - 题解
C#版 - Leetcode 13. 罗马数字转整数 - 题解 Leetcode 13. Roman to Integer 在线提交: https://leetcode.com/problems/ro ...
- Leetcode#13. Roman to Integer(罗马数字转整数)
题目描述 罗马数字包含以下七种字符:I, V, X, L,C,D 和 M. 字符 数值 I 1 V 5 X 10 L 50 C 100 D 500 M 1000 例如, 罗马数字 2 写做 II ,即 ...
- 【LeetCode】13. 罗马数字转整数
题目 罗马数字包含以下七种字符: I, V, X, L,C,D 和 M. 字符 数值 I 1 V 5 X 10 L 50 C 100 D 500 M 1000 例如, 罗马数字 2 写做 II ,即为 ...
- Newtonsoft.Json C# Json序列化和反序列化工具的使用、类型方法大全 C# 算法题系列(二) 各位相加、整数反转、回文数、罗马数字转整数 C# 算法题系列(一) 两数之和、无重复字符的最长子串 DateTime Tips c#发送邮件,可发送多个附件 MVC图片上传详解
Newtonsoft.Json C# Json序列化和反序列化工具的使用.类型方法大全 Newtonsoft.Json Newtonsoft.Json 是.Net平台操作Json的工具,他的介绍就 ...
- LeetCode 13 Roman to Integer(罗马数字转为整数)
题目链接 https://leetcode.com/problems/roman-to-integer/?tab=Description int toNumber(char ch) { switc ...
- C# 算法题系列(二) 各位相加、整数反转、回文数、罗马数字转整数
各位相加 给定一个非负整数 num,反复将各个位上的数字相加,直到结果为一位数. 示例: 输入: 输出: 解释: 各位相加的过程为: + = , + = . 由于 是一位数,所以返回 . 进阶:你可以 ...
- Leecode刷题之旅-C语言/python-13.罗马数字转整数
/* * @lc app=leetcode.cn id=13 lang=c * * [13] 罗马数字转整数 * * https://leetcode-cn.com/problems/roman-to ...
- LeetCode:罗马数字转整数【13】
LeetCode:罗马数字转整数[13] 题目描述 罗马数字包含以下七种字符: I, V, X, L,C,D 和 M. 字符 数值 I 1 V 5 X 10 L 50 C 100 D 500 M 10 ...
- 13. Roman to Integer[E]罗马数字转整数
题目 Given a roman numeral, convert it to an integer. Input is guaranteed to be within the range from ...
随机推荐
- LearnOpenGL学习笔记(二)——着色器简单理解
着色器在OpenGL中发挥着重要作用,它就像一个画笔,将输入的数据流,转为数学坐标,再将三维坐标变成二维坐标(针对我们现在用的二维显示器,全息显示器肯是三维的),再把二维坐标实际的像素点位置(这里面肯 ...
- kafka server管理
kafka启动以来zookeeper kafka启动之前,首先要启动zookeeper 1.1.kafka启动单个节点 -daemon 表示程序以守护进程的方式后台云心 --override pro ...
- leetcode — string-to-integer-atoi
/** * Source : https://oj.leetcode.com/problems/string-to-integer-atoi/ * * Created by lverpeng on 2 ...
- ASP.NET MVC5 + EF6 + LayUI实战教程,通用后台管理系统框架(3)
前言 本节将我们自己的CSS样式替换系统自带的 开始搭建 将脚本文件夹删掉,将内容文件夹里的内容删掉,将我们自己的CSS样式文件,全部复制到内容里边 新建家庭控制器 给家庭控制器添加索引视图 指数代码 ...
- 3DLut表实现log视频的后期调色原理
现在越来越多的视频或者图像拍摄设备支持log模式,比如大疆无人机的D-Log模式等等,log模式的起源和发展就不多做介绍,其在普通显示器上显示画面通常看起来是平坦的灰色,因此也常被称为log灰视频. ...
- Java与c#的一些细节区别
实习中用的语言是c#,第一次接触到这种语言,然后写的过程中,发觉和Java几乎一摸一样,好像根本是无缝切换,但细节仍有很大的区别,称有空总结一波里面的部分细节实现. ps. 我写c#过程中,发觉c#有 ...
- 牛刀小试MySQL--GTID
GTID的概念 何为GITD GTID(global transaction identifier)是全局事务标识符,在MySQL5.6版本中作为一个超级特性被推出.事务标识不仅对于Master(起源 ...
- java界面设计(swing)
1.Swing基本组件 窗体控件 JFrame.容器控件 JPanel .标签控件 JLabe.按钮控件 JButton.文本框控件 JTextField 与 JTextArea(注意JScrollP ...
- Vim 匹配相同的单词并高亮
将光标移动到要匹配的单词处: "g + d" :高亮显示所有相同的单词 shift + "*" :向下查找相同单词并高亮显示 shift + "#&q ...
- Python使用@property装饰类方法
Python版本:3.5.2 假如我们有一个Student类,并在其中定义了一个score属性,但是score属性会被显露出去,没办法检查参数,导致成绩可以随意更改: stu = Student() ...