Skip to content

Commit cd11cb2

Browse files
authored
Add files via upload
1 parent ca6a7a4 commit cd11cb2

File tree

1 file changed

+137
-0
lines changed

1 file changed

+137
-0
lines changed

13、罗马数字转整数.md

+137
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,137 @@
1+
# 13、罗马数字转整数
2+
3+
罗马数字包含以下七种字符: I, V, X, L,C,D 和 M。
4+
5+
```
6+
字符 数值
7+
I 1
8+
V 5
9+
X 10
10+
L 50
11+
C 100
12+
D 500
13+
M 1000
14+
```
15+
16+
17+
例如, 罗马数字 2 写做 II ,即为两个并列的 1 。12 写做 XII ,即为 X + II 。 27 写做 XXVII, 即为 XX + V + II 。
18+
19+
通常情况下,罗马数字中小的数字在大的数字的右边。但也存在特例,例如 4 不写做 IIII,而是 IV。数字 1 在数字 5 的左边,所表示的数等于大数 5 减小数 1 得到的数值 4 。同样地,数字 9 表示为 IX。这个特殊的规则只适用于以下六种情况:
20+
21+
I 可以放在 V (5) 和 X (10) 的左边,来表示 4 和 9。
22+
X 可以放在 L (50) 和 C (100) 的左边,来表示 40 和 90。
23+
C 可以放在 D (500) 和 M (1000) 的左边,来表示 400 和 900。
24+
给定一个罗马数字,将其转换成整数。
25+
26+
27+
28+
示例 1:
29+
30+
```
31+
输入: s = "III"
32+
输出: 3
33+
```
34+
35+
36+
示例 2:
37+
38+
```
39+
输入: s = "IV"
40+
输出: 4
41+
```
42+
43+
44+
示例 3:
45+
46+
```
47+
输入: s = "IX"
48+
输出: 9
49+
```
50+
51+
52+
示例 4:
53+
54+
```
55+
输入: s = "LVIII"
56+
输出: 58
57+
解释: L = 50, V= 5, III = 3.
58+
```
59+
60+
61+
示例 5:
62+
63+
```
64+
输入: s = "MCMXCIV"
65+
输出: 1994
66+
解释: M = 1000, CM = 900, XC = 90, IV = 4.
67+
```
68+
69+
70+
提示:
71+
72+
1 <= s.length <= 15
73+
s 仅含字符 ('I', 'V', 'X', 'L', 'C', 'D', 'M')
74+
题目数据保证 s 是一个有效的罗马数字,且表示整数在范围 [1, 3999]
75+
题目所给测试用例皆符合罗马数字书写规则,不会出现跨位等情况。
76+
IL 和 IM 这样的例子并不符合题目要求,49 应该写作 XLIX,999 应该写作 CMXCIX 。
77+
关于罗马数字的详尽书写规则,可以参考 罗马数字 - Mathematics 。
78+
79+
来源:力扣(LeetCode)
80+
链接:https://leetcode-cn.com/problems/roman-to-integer
81+
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
82+
83+
c语言
84+
85+
```c
86+
int romanToInt(char * s){
87+
int symbolValues[26];
88+
symbolValues['I' - 'A'] = 1;
89+
symbolValues['V' - 'A'] = 5;
90+
symbolValues['X' - 'A'] = 10;
91+
symbolValues['L' - 'A'] = 50;
92+
symbolValues['C' - 'A'] = 100;
93+
symbolValues['D' - 'A'] = 500;
94+
symbolValues['M' - 'A'] = 1000;
95+
int ans = 0;
96+
int n = strlen(s);
97+
for (int i = 0; i < n; ++i) {
98+
int value = symbolValues[s[i] - 'A'];
99+
if (i < n - 1 && value < symbolValues[s[i + 1] - 'A']) {
100+
ans -= value;
101+
} else {
102+
ans += value;
103+
}
104+
}
105+
return ans;
106+
107+
}
108+
```
109+
110+
java语言实现
111+
112+
```java
113+
class Solution {
114+
public int romanToInt(String s) {
115+
char []s1 = s.toCharArray();
116+
int[]s2 = new int[26];
117+
s2['I'-'A'] = 1;
118+
s2['V'-'A'] = 5;
119+
s2['X'-'A'] = 10;
120+
s2['L'-'A'] = 50;
121+
s2['C'-'A'] = 100;
122+
s2['D'-'A'] = 500;
123+
s2['M'-'A'] = 1000;
124+
int sum = 0;
125+
for(int i = 0;i<s1.length;i++){
126+
int value = s2[s1[i]-'A'];
127+
if((i<s1.length-1)&&(value<s2[s1[i+1]-'A'])){
128+
sum-=value;
129+
}else{
130+
sum+=value;
131+
}
132+
}
133+
return sum;
134+
}
135+
}
136+
```
137+

0 commit comments

Comments
 (0)