leetcode刷题日记——罗马数字转整数
[ 题目描述 ]:
 
 [ 思路 ]:
- 题目要求将一个给出的罗马数字表示的字符串转换为阿拉伯数字
- 先判别 I、X、C三个字符能否与下一个字符组成新的数字 
  - 能组成,则全部转换,下标向后移动两位
- 不能组成,则转换当前字符,下标向后移动一位
 
- 其余字符按照规则转换,没有技巧,全是暴力
- 也可以用switch-case,代码结构会清晰点
- 运行如下

int romanToInt(char* s) {
    int i=0,sum=0;
    while(s[i]!='\0'){
        if(s[i]=='I'){
            if(s[i+1]=='V'){
                sum+=4;
                i+=2;
            }else if(s[i+1]=='X'){
                sum+=9;
                i+=2;
            }else{
                i+=1;
                sum+=1;
            }
            continue;
        }
        if(s[i]=='X'){
            if(s[i+1]=='L'){
                sum+=40;
                i+=2;
            }else if(s[i+1]=='C'){
                sum+=90;
                i+=2;
            }else{
                i+=1;
                sum+=10;
            }
            continue;
        }
        if(s[i]=='C'){
            if(s[i+1]=='D'){
                sum+=400;
                i+=2;
            }else if(s[i+1]=='M'){
                sum+=900;
                i+=2;
            }else{
                i+=1;
                sum+=100;
            }
            continue;
        }
        if(s[i]=='V') sum+=5;
        if(s[i]=='L') sum+=50;
        if(s[i]=='D') sum+=500;
        if(s[i]=='M') sum+=1000;
        i++;
    }
    return sum;
}
[ 官方题解 ]:
- 一、模拟 
  - 通常情况下,罗马数字中小的数字在大的数字的右边。若输入的字符串满足该情况,那么可以将每个字符视作一个单独的值,累加每个字符对应的数值即可。
- 若存在小的数字在大的数字的左边的情况,根据规则需要减去小的数字。对于这种情况,我们也可以将每个字符视作一个单独的值,若一个数字右侧的数字比它大,则将该数字的符号取反。
 
int romanToInt(char* s) {
    int symbolValues[26];
    symbolValues['I' - 'A'] = 1;
    symbolValues['V' - 'A'] = 5;
    symbolValues['X' - 'A'] = 10;
    symbolValues['L' - 'A'] = 50;
    symbolValues['C' - 'A'] = 100;
    symbolValues['D' - 'A'] = 500;
    symbolValues['M' - 'A'] = 1000;
    int ans = 0;
    int n = strlen(s);
    for (int i = 0; i < n; ++i) {
        int value = symbolValues[s[i] - 'A'];
        if (i < n - 1 && value < symbolValues[s[i + 1] - 'A']) {
            ans -= value;
        } else {
            ans += value;
        }
    }
    return ans;
}
