LeetCodeOJ刷题之13【Roman to Integer】
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
-
- 这种方法是对罗马数字从头到尾的扫描一遍。分析一下可以知道,只有 4 和 9 才会出现小一点的罗马数字出现在大的罗马数字的前面!比如:
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;
}
}; - 这种方法是对罗马数字从头到尾的扫描一遍。分析一下可以知道,只有 4 和 9 才会出现小一点的罗马数字出现在大的罗马数字的前面!比如:
-
- 方案1中需要考虑 idx+1 的越界情况,所以还要在最后再增加一个判断,且使用的是从前向后扫描罗马数字字串;那如果是从后向前扫描罗马数字字串呢?思想会不会简单一点呢?分析一下可以看出,从后向前扫描,可以一直加下去,除了一种情况:当前扫描的数小于上一个扫描的数!也就是说只有这一个条件了,不需要再判断什么越不越界的问题了。如:
MCMVI=1906
, 扫描V
时V>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;
}
};
- 方案1中需要考虑 idx+1 的越界情况,所以还要在最后再增加一个判断,且使用的是从前向后扫描罗马数字字串;那如果是从后向前扫描罗马数字字串呢?思想会不会简单一点呢?分析一下可以看出,从后向前扫描,可以一直加下去,除了一种情况:当前扫描的数小于上一个扫描的数!也就是说只有这一个条件了,不需要再判断什么越不越界的问题了。如:
-
- 查阅了网友的解答,发现这一个方式挺好的,思路也很简单:
- 逐个遍历罗马数字串,根据当前遍历到的字符,进行对应的累加操作。
- 罗马数字共 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】的更多相关文章
- 【leetcode刷题笔记】Roman to Integer
Given a roman numeral, convert it to an integer. Input is guaranteed to be within the range from 1 t ...
- leetCode练题——13. Roman to Integer
1.题目13. Roman to Integer Roman numerals are represented by seven different symbols: I, V, X, L, C, D ...
- 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 ,即 ...
- leecode刷题(13) -- 字符串中的第一个唯一字符
leecode刷题(13) -- 字符串中的第一个唯一字符 字符串中的第一个唯一字符 描述: 给定一个字符串,找到它的第一个不重复的字符,并返回它的索引.如果不存在,则返回 -1. 案例: s = & ...
- Leetcode 13. Roman to Integer(水)
13. Roman to Integer Easy Roman numerals are represented by seven different symbols: I, V, X, L, C, ...
- 《LeetBook》leetcode题解(13):Roman to Integer[E]
我现在在做一个叫<leetbook>的免费开源书项目,力求提供最易懂的中文思路,目前把解题思路都同步更新到gitbook上了,需要的同学可以去看看 书的地址:https://hk029.g ...
- 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 ...
- 13. Roman to Integer【leetcode】
Roman to Integer Given a roman numeral, convert it to an integer. Input is guaranteed to be within t ...
- 【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 ...
随机推荐
- G: 又见模法师
G: 又见模法师 Time Limit: 1 s Memory Limit: 128 MB #include <stdio.h> ; typedef long lo ...
- 基于scrapy的一些实例
一.爬取斗鱼主播 1. 爬虫文件 # -*- coding: utf-8 -*- import scrapy import json from Douyu.items import DouyuItem ...
- spring初始化bean的目的
初始化bean就是为了将所有需要的bean全部装载到容器里面,等我们需要用到哪个bean就将哪个bean从容器里面拿出来
- GreenPlum 大数据平台--备份-邮件配置-gpcrondump & gpdbrestore(五)
01,备份 生成备份数据库 [gpadmin@greenplum01 ~]$ gpcrondump -l /gpbackup/back2/gpcorndump.log -x postgres -v [ ...
- 一个典型案例为你解读TDSQL 全时态数据库系统
欢迎大家前往腾讯云+社区,获取更多腾讯海量技术实践干货哦~ 本文由腾讯技术工程官方号发表在腾讯云+社区 经典案例 增量抽取.增量计算等都是T-TDSQL的经典案例.如下以增量计算为例,来分析T-TDS ...
- Java对象的生命周期与作用域的讨论(转)
导读: Java对象的生命周期大致包括三个阶段:对象的创建,对象的使用,对象的清除.因此,对象的生命周期长度可用如下的表达式表示:T = T1 + T2 +T3.其中T1表示对象的创建时间,T2表示对 ...
- [转]<加密算法c#>——— 3DES加密之ECB模式 和 CBC模式
本文转自:http://www.cnblogs.com/qq278360339/archive/2013/06/05/3119222.html 最近 一个项目.net 要调用JAVA的WEB SERV ...
- 1、v1 与 v2的比较
1.路由的迁移 /* --- v1 ----*/ .config(function($stateProvider){ $stateProvider .state('main', { url: '/', ...
- 调试.NET程序OutOfMemoryException (转载)
原文地址:http://blog.csdn.net/directionofear/article/details/8009427 应用程序调试,需要有个常规的调试思路,应对各类问题最基本的调试手段是什 ...
- 进程 multiprocessing详解
一 ,核心 就是像线程一样管理进程 ,类似于threading ,cup利用率较好,该模块用来跨平台的多进程模块,含有一个Process 类代表进程对象,start() 启动进程 Process语法结 ...