zoukankan      html  css  js  c++  java
  • [leetcode] 13. 罗马数字转整数

    13. 罗马数字转整数

    字符串处理,完全是上一个题倒过来,同样从大到小干就可以了

    class Solution {
    public:
        int romanToInt(string s) {
            int ans = 0;
            int k = 0;
    
            while (k < s.size() && s[k] == 'M') {
                ans += 1000;
                k++;
            }
            if (k < s.size() && s[k] == 'C' && s[k + 1] == 'M') {
                ans += 900;
                k += 2;
            }
            if (k < s.size() && s[k] == 'C' && s[k + 1] == 'D') {
                ans += 400;
                k += 2;
            }
            if (k < s.size() && s[k] == 'D') {
                ans += 500;
                k++;
            }
            while (k < s.size() && s[k] == 'C') {
                ans += 100;
                k++;
            }
            if (k < s.size() && s[k] == 'X' && s[k + 1] == 'C') {
                ans += 90;
                k += 2;
            }
            if (k < s.size() && s[k] == 'X' && s[k + 1] == 'L') {
                ans += 40;
                k += 2;
            }
            if (k < s.size() && s[k] == 'L') {
                ans += 50;
                k++;
            }
            while (k < s.size() && s[k] == 'X') {
                ans += 10;
                k++;
            }
            if (k < s.size() && s[k] == 'I' && s[k + 1] == 'X') {
                ans += 9;
                k += 2;
            }
            if (k < s.size() && s[k] == 'I' && s[k + 1] == 'V') {
                ans += 4;
                k += 2;
            }
            if (k < s.size() && s[k] == 'V') {
                ans += 5;
                k++;
            }
            while (k < s.size() && s[k] == 'I') {
                ans += 1;
                k++;
            }
    
            return ans;
        }
    };
    
  • 相关阅读:
    泛型
    事件和委托
    参数和属性
    常量、字段、和方法
    LINQ
    LINQ- 子查询、组合策略、投影策略
    MySQL全局锁和表锁
    CLR基础
    LINQ
    LINQ
  • 原文地址:https://www.cnblogs.com/acbingo/p/9231692.html
Copyright © 2011-2022 走看看