- 羅馬數(shù)字包含以下七種字符: I乎折, V, X侵歇, L骂澄,C,D 和 M盒至。
字符 數(shù)值
I 1
V 5
X 10
L 50
C 100
D 500
M 1000
例如酗洒, 羅馬數(shù)字 2 寫做 II ,即為兩個并列的 1枷遂。12 寫做 XII 樱衷,即為 X + II 。 27 寫做 XXVII, 即為 XX + V + II 酒唉。
通常情況下矩桂,羅馬數(shù)字中小的數(shù)字在大的數(shù)字的右邊。但也存在特例痪伦,例如 4 不寫做 IIII侄榴,而是 IV。數(shù)字 1 在數(shù)字 5 的左邊网沾,所表示的數(shù)等于大數(shù) 5 減小數(shù) 1 得到的數(shù)值 4 癞蚕。同樣地,數(shù)字 9 表示為 IX辉哥。這個特殊的規(guī)則只適用于以下六種情況:
I 可以放在 V (5) 和 X (10) 的左邊桦山,來表示 4 和 9攒射。
X 可以放在 L (50) 和 C (100) 的左邊,來表示 40 和 90恒水。
C 可以放在 D (500) 和 M (1000) 的左邊会放,來表示 400 和 900。
- 給定一個羅馬數(shù)字钉凌,將其轉(zhuǎn)換成整數(shù)咧最。輸入確保在 1 到 3999 的范圍內(nèi)。
// 羅馬數(shù)轉(zhuǎn)數(shù)字
func RomanToInt(s string) int {
var resInt int
baseMap := make(map[string]int, 7)
baseMap = map[string]int{"I": 1, "V": 5, "X": 10, "L": 50, "C": 100, "D": 500, "M": 1000}
if len(s) == 1 {
resInt = int(baseMap[string(s)])
return resInt
}
resSlice := make([]string, 0)
for i := 0; i < len(s)-1; i++ {
if baseMap[string(s[i])] < baseMap[string(s[i+1])] {
resSlice = append(resSlice, string(s[i])+string(s[i+1]))
i++
} else {
resSlice = append(resSlice, string(s[i]))
}
if i == len(s)-1-1 {
resSlice = append(resSlice, string(s[i+1]))
}
}
var tempInt int
for _, value := range resSlice {
if len(value) == 1 {
tempInt = int(baseMap[string(value)])
} else {
runes := []rune(value)
tempInt = int(baseMap[string(runes[1])] - baseMap[string(runes[0])])
}
resInt += tempInt
}
return resInt
}