leetCode 罗马数字转整数
解析:
首先建立一个HashMap来映射符号和值,然后对字符串从左到右来,如果当前字符代表的值不小于其右边,就加上该值;否则就减去该值。以此类推到最左边的数,最终得到的结果即是答案
func romanToInt(s string) int {
var romanMap map[rune]int
var result int
var strRune=[]rune(s)
romanMap=make(map[rune]int,7)
romanMap['I']=1
romanMap['V']=5
romanMap['X']=10
romanMap['L']=50
romanMap['C']=100
romanMap['D']=500
romanMap['M']=1000
for i:=0;i<len(strRune)-1;i++{
if romanMap[strRune[i]]<romanMap[strRune[i+1]]{
result-=romanMap[strRune[i]]
}else{
result+=romanMap[strRune[i]]
}
}
result+=romanMap[strRune[len(strRune)-1]]
return result
}