[leetcode] Roman to Integer

來源:互聯網
上載者:User

標籤:class   blog   code   java   http   tar   

Given a roman numeral, convert it to an integer.

Input is guaranteed to be within the range from 1 to 3999.

https://oj.leetcode.com/problems/roman-to-integer/

思路1:從前向後遍曆羅馬數字,如果某個數比前一個數小,則加上該數。反之,減去前一個數的兩倍然後加上該數。

public class Solution {    public int romanToInt(String s) {        char[] symbol = { ‘I‘, ‘V‘, ‘X‘, ‘L‘, ‘C‘, ‘D‘, ‘M‘ };        int[] val = { 1, 5, 10, 50, 100, 500, 1000 };        Map<Character, Integer> map = new HashMap<Character, Integer>();        for (int i = 0; i < symbol.length; i++)            map.put(symbol[i], val[i]);        int len = s.length();        int res = 0;        res += map.get(s.charAt(0));        for (int i = 1; i < len; i++) {            int cur = map.get(s.charAt(i));            int pre = map.get(s.charAt(i - 1));            if (cur <= pre) {                res += cur;            } else {                res = res + cur - 2 * pre;            }        }        return res;    }    public static void main(String[] args) {        System.out.println(new Solution().romanToInt("MCMXC"));    }}

 

 

參考:

http://blog.csdn.net/wzy_1988/article/details/17057929

 

 

 

 

 

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.