Question:

Given a roman numeral, convert it to an integer.

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

给一个罗马数字,把它转化成阿拉伯数字,可以保证罗马数字的输入在1到3999之间。

这个题和我上篇文章写的《leetcode:Integer to Roman(整数转化为罗马数字》正好相反,在上一篇文章中,我简单介绍了罗马数字的计数方法和组数规则,并举了一些例子,大家可以参考,在这里我再介绍。这个题我写的代码不简洁,甚至有些繁琐,但是思路简单明了,肯定还有更多比这更好的方法,但是它作为一种思路,也通过了leetcode的测试,愿意和大家分享一下,一起学习,共同进步。

算法基本思想:① 罗马构造数字有一定规律,虽然表示个位、十位、百位、千位的字母不同,但是这种规律相同,可以把这种构词规律写成一个函数 public int romanToOneNo(String s,int i),s表示构成罗马数字个位或者十位或者百位或者千位的罗马字母,i=1表示个位,i=2表示十位,i=3表示百位,i=4表示千位,经过这样的转换,可以转换成相应位上的数字。

       ② 在public int romanToInt(String s)中,s就是要转换的罗马字符串,下面的问题就转变为怎样分割字符串s,使个位、十位、百位、千位的字母分离出来。依次调用romanToOneNo(String s,int i)函数,就可以得到各位上的值。

       ③ 设计一个sum变量,对各位上的数乘以相应的1000、100、10、1,返回sum就可以了。

代码实现(java):

 class Solution13 {
public int romanToInt(String s) {
// Note: The Solution object is instantiated only once and is reused by each test case.
int sum=0;
String Temp="";
int i=0;
while(i<s.length()&&s.charAt(i)=='M'){
Temp+=s.charAt(i); //这个循环的目的就是把表示千位上的罗马字母依次累加到Temp
i++;
}
sum+=1000*romanToOneNo(Temp, 4);
Temp="";
while(i<s.length()&&(s.charAt(i)=='C'||s.charAt(i)=='D'||s.charAt(i)=='M')){
Temp+=s.charAt(i); //这个循环的目的就是把表示百位上的罗马字母依次累加到Temp
i++;
}
sum+=100*romanToOneNo(Temp, 3);
Temp="";
while(i<s.length()&&(s.charAt(i)=='X'||s.charAt(i)=='L'||s.charAt(i)=='C')){
Temp+=s.charAt(i); //这个循环的目的就是把表示十位上的罗马字母依次累加到Temp
i++;
}
sum+=10*romanToOneNo(Temp, 2);
Temp="";
//System.out.println("The program is running");
while(i<s.length()&&(s.charAt(i)=='I'||s.charAt(i)=='V'||s.charAt(i)=='X')){
Temp+=s.charAt(i); //这个循环的目的就是把表示个位上的罗马字母依次累加到Temp
i++;
}
sum+=romanToOneNo(Temp, 1);
return sum;
}
public int romanToOneNo(String s,int i){//这个函数的作用就是转化应该是i位上的字符串为单个的数,
//s字符串表示的数转换后应该在i位上
String str1,str2,str3;//拿0~9之间的数举例,str1表示I,str2表示V,str3表示X
if(1==i){ //下面if语句是判断n是哪一位上的,依次用罗马数字表示1、5、10
str1="I"; //个位上的数
str2="V";
str3="X";
}
else if(2==i){
str1="X"; //十位上的数
str2="L";
str3="C";
}else if(3==i){
str1="C"; //百位上的数
str2="D";
str3="M";
}else{
str1="M"; //千位上的数,因为最大数到3999,所以str2和str3为空
str2="";
str3="";
}
if(s.equals("")) //下面以个位数字0~9为例说明,如果字符串为空,返回0
return 0;
if(s.equals(str1)) //如果s为“I”
return 1;
if(s.equals(str1+str1)) //如果s为“II”
return 2;
if(s.equals(str1+str1+str1))//如果s为“III”
return 3;
if(s.equals(str1+str2)) //如果s为“IV”
return 4;
if(s.equals(str2))//如果s为“V”
return 5;
if(s.equals(str2+str1))//如果s为“VI”
return 6;
if(s.equals(str2+str1+str1))//如果s为“VII”
return 7;
if(s.equals(str2+str1+str1+str1))//如果s为“VIII”
return 8;
if(s.equals(str1+str3)) //如果s为“IX”
return 9;
return -1; //如果以上条件都不符合,只能说明s不符合罗马数字的构词规则
}
}

leetcode:Roman to Integer(罗马数字转化为罗马数字)的更多相关文章

  1. LeetCode:Roman to Integer,Integer to Roman

    首先简单介绍一下罗马数字,一下摘自维基百科 罗马数字共有7个,即I(1).V(5).X(10).L(50).C(100).D(500)和M(1000).按照下述的规则可以表示任意正整数.需要注意的是罗 ...

  2. LeetCode: Roman to Integer 解题报告

    Roman to IntegerGiven a roman numeral, convert it to an integer. Input is guaranteed to be within th ...

  3. [LeetCode] Roman to Integer 罗马数字转化成整数

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

  4. [Leetcode] Roman to integer 罗马数字转成整数

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

  5. [Leetcode] Roman to Integer

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

  6. leetcode Roman to Integer python

    class Solution(object): def romanToInt(self, s): """ :type s: str :rtype: int "& ...

  7. [LeetCode] Integer to Roman 整数转化成罗马数字

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

  8. [LeetCode] 12. Integer to Roman 整数转化成罗马数字

    Roman numerals are represented by seven different symbols: I, V, X, L, C, D and M. Symbol Value I 1 ...

  9. leetcode:Integer to Roman(整数转化为罗马数字)

    Question: Given an integer, convert it to a roman numeral. Input is guaranteed to be within the rang ...

随机推荐

  1. SQL Server 联表字段合并查询

    经常遇到统计报表中,子表记录合并为一个字段的情况.例如:省表中各省经济水平前五的城市统计. 有如下两表:dbo.省 和 dbo.市 (好吧,你可能会吐槽为什么用中文表名,其实我是为了方便查找替换) 这 ...

  2. 【分享】IT产业中的三大定理(一) —— 摩尔定理(Moore's Law)

    科技行业流传着很多关于比尔·盖茨的故事,其中一个是他和通用汽车公司老板之间的对话.盖茨说,如果汽车工业能够像计算机领域一样发展,那么今天,买一辆汽车只需要 25 美元,一升汽油能跑四百公里.通用汽车老 ...

  3. HDU4749 Parade Show(KMP)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4749 题意:给出两个数字串A.B.问A中有多少不相交的子串a能匹配B.匹配的意思是a中任意两个位置i和 ...

  4. [NYIST15]括号匹配(二)(区间dp)

    题目链接:http://acm.nyist.edu.cn/JudgeOnline/problem.php?pid=15 经典区间dp,首先枚举区间的大小和该区间的左边界,这时右边界也可计算出来.首先初 ...

  5. visual studio 中删除多余的空白行

    替换  Ctrl+H  正则  勾选  替换 ^\s*\n 为空

  6. android 内存溢出问题分析

      最近的项目中,内存一直再增长,但是不知道是什么问题,导致内存溢出,在网上看到了这么一篇关于内存分析与管理的文章,解决了部分问题,感觉这篇文 章还不错,就转帖到我的blog上了,希望对大家有所帮助. ...

  7. POJ 1988 Cube Stacking

    题意:有编号为1~N的N个小木块,有两种操作 M x y 将木块x所在的堆放到木块y所在的堆的上面 C x 询问木块x下面有多少块木块 代码巧妙就巧妙在GetParent函数中在进行路径压缩的同时,也 ...

  8. HDU 5269 ZYB loves Xor I (二分法)

    题意: 给出一个序列,对每两个数求异或结果后取最低位的1出来作为一个数,然后求这些数字的和.比如:{a,b,c},结果是lowbit(a^b)+lowbit(a^c)+lowbit(b^a)+lowb ...

  9. python 包管理

    如果导入的模块和主程序在同个目录下,直接import就行了 2.如果导入的模块是在主程序所在目录的子目录下,可以在子目录中增加一个空白的__init__.py文件,该文件使得python解释器将子目录 ...

  10. phpcms还原被删除的栏目

    1.在这个目录下/caches/bakup/default导出文件category.sql 2.登录网站的数据管理页面phpmyadmin 3.导入数据库选择category.sql 4.登陆网站后台 ...