罗马数字包含以下七种字符: 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": }//正常罗马数字
  1. 然后我们就要对给定的字符串去取字符
  2. 但是当我们取到一个字符的时候,我们还得再取一个字符,用两个字符去特殊的map去查找是否存在
  3. 当存在的时候我们就记录下值
  4. 当没有的时候,我们就用第一个字符去正常的罗马数字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实现的更多相关文章

  1. C#版 - Leetcode 13. 罗马数字转整数 - 题解

    C#版 - Leetcode 13. 罗马数字转整数 - 题解 Leetcode 13. Roman to Integer 在线提交: https://leetcode.com/problems/ro ...

  2. 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 ,即 ...

  3. 【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 ,即为 ...

  4. Newtonsoft.Json C# Json序列化和反序列化工具的使用、类型方法大全 C# 算法题系列(二) 各位相加、整数反转、回文数、罗马数字转整数 C# 算法题系列(一) 两数之和、无重复字符的最长子串 DateTime Tips c#发送邮件,可发送多个附件 MVC图片上传详解

    Newtonsoft.Json C# Json序列化和反序列化工具的使用.类型方法大全   Newtonsoft.Json Newtonsoft.Json 是.Net平台操作Json的工具,他的介绍就 ...

  5. LeetCode 13 Roman to Integer(罗马数字转为整数)

    题目链接 https://leetcode.com/problems/roman-to-integer/?tab=Description   int toNumber(char ch) { switc ...

  6. C# 算法题系列(二) 各位相加、整数反转、回文数、罗马数字转整数

    各位相加 给定一个非负整数 num,反复将各个位上的数字相加,直到结果为一位数. 示例: 输入: 输出: 解释: 各位相加的过程为: + = , + = . 由于 是一位数,所以返回 . 进阶:你可以 ...

  7. Leecode刷题之旅-C语言/python-13.罗马数字转整数

    /* * @lc app=leetcode.cn id=13 lang=c * * [13] 罗马数字转整数 * * https://leetcode-cn.com/problems/roman-to ...

  8. 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 ...

  9. 13. Roman to Integer[E]罗马数字转整数

    题目 Given a roman numeral, convert it to an integer. Input is guaranteed to be within the range from ...

随机推荐

  1. LearnOpenGL学习笔记(二)——着色器简单理解

    着色器在OpenGL中发挥着重要作用,它就像一个画笔,将输入的数据流,转为数学坐标,再将三维坐标变成二维坐标(针对我们现在用的二维显示器,全息显示器肯是三维的),再把二维坐标实际的像素点位置(这里面肯 ...

  2. kafka server管理

    kafka启动以来zookeeper  kafka启动之前,首先要启动zookeeper 1.1.kafka启动单个节点 -daemon 表示程序以守护进程的方式后台云心 --override pro ...

  3. leetcode — string-to-integer-atoi

    /** * Source : https://oj.leetcode.com/problems/string-to-integer-atoi/ * * Created by lverpeng on 2 ...

  4. ASP.NET MVC5 + EF6 + LayUI实战教程,通用后台管理系统框架(3)

    前言 本节将我们自己的CSS样式替换系统自带的 开始搭建 将脚本文件夹删掉,将内容文件夹里的内容删掉,将我们自己的CSS样式文件,全部复制到内容里边 新建家庭控制器 给家庭控制器添加索引视图 指数代码 ...

  5. 3DLut表实现log视频的后期调色原理

    现在越来越多的视频或者图像拍摄设备支持log模式,比如大疆无人机的D-Log模式等等,log模式的起源和发展就不多做介绍,其在普通显示器上显示画面通常看起来是平坦的灰色,因此也常被称为log灰视频. ...

  6. Java与c#的一些细节区别

    实习中用的语言是c#,第一次接触到这种语言,然后写的过程中,发觉和Java几乎一摸一样,好像根本是无缝切换,但细节仍有很大的区别,称有空总结一波里面的部分细节实现. ps. 我写c#过程中,发觉c#有 ...

  7. 牛刀小试MySQL--GTID

    GTID的概念 何为GITD GTID(global transaction identifier)是全局事务标识符,在MySQL5.6版本中作为一个超级特性被推出.事务标识不仅对于Master(起源 ...

  8. java界面设计(swing)

    1.Swing基本组件 窗体控件 JFrame.容器控件 JPanel .标签控件 JLabe.按钮控件 JButton.文本框控件 JTextField 与 JTextArea(注意JScrollP ...

  9. Vim 匹配相同的单词并高亮

    将光标移动到要匹配的单词处: "g + d" :高亮显示所有相同的单词 shift + "*" :向下查找相同单词并高亮显示 shift + "#&q ...

  10. Python使用@property装饰类方法

    Python版本:3.5.2 假如我们有一个Student类,并在其中定义了一个score属性,但是score属性会被显露出去,没办法检查参数,导致成绩可以随意更改: stu = Student() ...