Roman to Integer

Given a roman numeral, convert it to an integer.

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

意思就是:

给出一个罗马数字,返回其对应的整数 num( 0<=num<=3999)表示;

罗马数字范围从 0-->3999

罗马数字有:

I V X L C D M
1 5 10 50 100 500 1000

Solutions

  • 1 Roman to Integer -- 59ms

    • 这种方法是对罗马数字从头到尾的扫描一遍。分析一下可以知道,只有 49 才会出现小一点的罗马数字出现在大的罗马数字的前面!比如:CD=400 其中 C=100 , D=500 ,此时需要的后一个罗马数字减去前面一个罗马数字,其他情况都是一直加的。代码如下:
    class Solution {
    public:
    int romanToInt(string s) {
    int idx=0,n=s.length();
    if(s.length()<=0)return 0; string roman="IVXLCDM";
    int nums[] ={1,5,10,50,100,500,1000};
    int res=0;
    //idx=roman.find(s.at(0));
    //if(idx<0||idx>6)return 0;
    //if(n==1){
    //return nums[idx];
    //}
    int num1,num2;
    idx=0;
    while(idx<n-1){ // 需要考虑 idx+1 的越界情况
    num1=roman.find(s[idx]);
    num2=roman.find(s[idx+1]);
    if(num2>num1){
    res=res+(nums[num2]-nums[num1]);
    idx+=2;
    }else{
    res=res+nums[num1];
    ++idx;
    }
    }
    if(n-1==idx){ //需要考虑可能剩下的最后一个罗马数字
    num1=roman.find(s[n-1]);
    res+=nums[num1];
    }
    return res;
    }
    };
  • 2 Roman to Integer -- 49ms

    • 方案1中需要考虑 idx+1 的越界情况,所以还要在最后再增加一个判断,且使用的是从前向后扫描罗马数字字串;那如果是从后向前扫描罗马数字字串呢?思想会不会简单一点呢?分析一下可以看出,从后向前扫描,可以一直加下去,除了一种情况:当前扫描的数小于上一个扫描的数!也就是说只有这一个条件了,不需要再判断什么越不越界的问题了。如:MCMVI=1906 , 扫描 VV>I(在罗马数字中,以下同),所以直接加,结果为:6,扫描 M 也一样,结果为1006,接下来扫描到 C ,此时 C<M ,所以应是减去 C ,结果是906,最后再加 M ,得到结果:1906。要做的,只是记录下上一次的罗马数字。代码如下:
    class Solution {
    public:
    int romanToInt(string s) {
    if(s.length()<=0)return 0;
    string roman="IVXLCDM";
    int nums[] ={1,5,10,50,100,500,1000};
    int n=s.length();
    int res=0, idx=n-1, pre=0, ndx;
    while(idx>=0){
    ndx=roman.find(s[idx]);
    if(pre>ndx){
    res-=nums[ndx];
    }else{
    res+=nums[ndx];
    }
    pre=ndx;
    --idx;
    }
    return res;
    }
    };
  • 3 Roman to Integer -- 53ms

    • 查阅了网友的解答,发现这一个方式挺好的,思路也很简单:

      • 逐个遍历罗马数字串,根据当前遍历到的字符,进行对应的累加操作。
      • 罗马数字共 7 个符号,IVXLCDM ,如果遍历到罗马数字 w ,则判断之前已经求出的数字 res 是否小于 w ,如果小于,则 加上 w :res=res+w,否则减去 w 。原因是:因为是从后向前遍历,所以我们已经遍历出来的数字肯定是会小于下一进位的数字的,比如 189 ,89再大,也没有100大!所以此算法使用的就是这种思想,一旦出现违法了这种情况,那就是出现了 4 或者 9 的情况。说明我们加多了,那就要减去。说的可能比较不好完全理解,看代码:
    class Solution {
    public:
    int romanToInt(string s) {
    int res = 0 ,n=s.length();
    for (int i = n - 1; i >= 0; --i) {
    char c = s.at(i);
    switch (c) {
    case 'I':
    res += (res >= 5 ? -1 : 1);
    break;
    case 'V':
    res += 5;
    break;
    case 'X':
    res += 10 * (res >= 50 ? -1 : 1);
    break;
    case 'L':
    res += 50;
    break;
    case 'C':
    res += 100 * (res >= 500 ? -1 : 1);
    break;
    case 'D':
    res += 500;
    break;
    case 'M':
    res += 1000;
    break;
    }
    }
    return res;
    }
    };
  • 看了一下其他的代码,大致的思想都是上面的方法,可能还有我没发现的。只是代码编写的形式不同而已。

附录

同系列:LeetCodesOJhttp://www.cnblogs.com/lomper/tag/LeetCodesOJ/

LeetCodeOJ刷题之13【Roman to Integer】的更多相关文章

  1. 【leetcode刷题笔记】Roman to Integer

    Given a roman numeral, convert it to an integer. Input is guaranteed to be within the range from 1 t ...

  2. leetCode练题——13. Roman to Integer

    1.题目13. Roman to Integer Roman numerals are represented by seven different symbols: I, V, X, L, C, D ...

  3. Leetcode#13. Roman to Integer(罗马数字转整数)

    题目描述 罗马数字包含以下七种字符:I, V, X, L,C,D 和 M. 字符 数值 I 1 V 5 X 10 L 50 C 100 D 500 M 1000 例如, 罗马数字 2 写做 II ,即 ...

  4. leecode刷题(13) -- 字符串中的第一个唯一字符

    leecode刷题(13) -- 字符串中的第一个唯一字符 字符串中的第一个唯一字符 描述: 给定一个字符串,找到它的第一个不重复的字符,并返回它的索引.如果不存在,则返回 -1. 案例: s = & ...

  5. Leetcode 13. Roman to Integer(水)

    13. Roman to Integer Easy Roman numerals are represented by seven different symbols: I, V, X, L, C, ...

  6. 《LeetBook》leetcode题解(13):Roman to Integer[E]

    我现在在做一个叫<leetbook>的免费开源书项目,力求提供最易懂的中文思路,目前把解题思路都同步更新到gitbook上了,需要的同学可以去看看 书的地址:https://hk029.g ...

  7. C# 写 LeetCode easy #13 Roman to Integer

    13.Roman to Integer Roman numerals are represented by seven different symbols: I, V, X, L, C, D and  ...

  8. 13. Roman to Integer【leetcode】

    Roman to Integer Given a roman numeral, convert it to an integer. Input is guaranteed to be within t ...

  9. 【LeetCode】13. Roman to Integer (2 solutions)

    Roman to Integer Given a roman numeral, convert it to an integer. Input is guaranteed to be within t ...

随机推荐

  1. C++ GUI Qt4编程(09)-3.3spreadsheet-toolbar

    1. C++ GUI Qt4编程第三章,增加工具栏.状态栏和快捷键. 2. mainwindow.h /**/ #ifndef MAINWINDOW_H #define MAINWINDOW_H #i ...

  2. HTML5之WebSocket && https://zhuanlan.zhihu.com/p/23467317

    在认识websocket之前,我们必须了解的是websocket有什么用? 他能解决我们遇到的什么问题? 如果没用,那么我们就么有使用它的必要的. websocket就是建立起全双工协议的,提高了效率 ...

  3. storm中KafkaSpout的选择

    Storm最常用的消息源就是Kafka,在对接的时候大多需要使用KafkaSpout: 在网上大概有两种KafkaSpout,一种是只有几十行,一种却有一大啪啦类文件. 在kafka中,同一个part ...

  4. TOJ 1023 Taxi Cab Scheme

    Description Running a taxi station is not all that simple. Apart from the obvious demand for a centr ...

  5. ife task0003学习笔记(三):JavaScript闭包

    一.this易错分析 在学习闭包的时候,有一个概念this很重要,关于this的理解,下面3种情况:this指向谁? fn.call(obj1); obj2.fn() fn() 答案是obj1 obj ...

  6. 数据段描述符和代码段描述符(一)——《x86汇编语言:从实模式到保护模式》读书笔记10

    一.段描述符的分类 在上一篇博文中已经说过,为了使用段,我们必须要创建段描述符.80X86中有各种各样的段描述符,下图展示了它们的分类. 看了上图,你也许会说:天啊,怎么这么多段描述符啊!我可怎么记住 ...

  7. IIS7部署网站出现500.19错误(权限不足)的解决方案

    错误摘要 HTTP 错误 500.19 - Internal Server Error 无法访问请求的页面,因为该页的相关配置数据无效. 详细错误信息 模块 IIS Web Core 通知 未知 处理 ...

  8. 初学SqlHelper - 实现增删改查

    //数据库连接字符串 public static readonly string constr = ConfigurationManager.ConnectionStrings["conns ...

  9. 4.net两种交互模式

    .net两种交互模式 (1) C/S:客户端(Client)/服务器模式(Server) (2) B/S:浏览器(Browser)/服务器模式(Server)   来自为知笔记(Wiz)

  10. Quartz使用及注意事项

    Quartz使用及注意事项 前提:目前由于公司业务决定,大量使用Quartz,每天固定的时间点执行相应的业务逻辑,,几十个时间点应该是有的,某一个时间点如果没有执行带来的问题是巨大的.Quartz的稳 ...