13. Roman to Integer
Given a roman numeral, convert it to an integer.
Input is guaranteed to be within the range from 1 to 3999.
這道題蜈亩,是要我們將羅馬數(shù)字轉(zhuǎn)換成十進(jìn)制數(shù)字姻乓,屬于一道水題菊碟,就不過(guò)多的介紹了嫡锌,直接上代碼了痊末。
java代碼:
class Solution {
public int romanToInt(String s) {
int i, total, pre, cur;
total = charToInt(s.charAt(0));
for(i = 1;i<s.length();i++){
pre = charToInt(s.charAt(i-1));
cur = charToInt(s.charAt(i));
if (cur<=pre){
total+=cur;
}else {
total=total -pre*2+cur;
}
}
return total;
}
public static int charToInt(char c) {
int data = 0;
switch (c) {
case 'I':
data = 1;
break;
case 'V':
data = 5;
break;
case 'X':
data = 10;
break;
case 'L':
data = 50;
break;
case 'C':
data = 100;
break;
case 'D':
data = 500;
break;
case 'M':
data = 1000;
break;
}
return data;
}
}