题目描述
罗马数字转整数
首次实现方法:辨析字符,直接做转换。(这里的字串长度并不能提取出有用的信息)
思路是从低位开始辨析字符并转换,
如果当前的转换字符比上一个字符小,那就减当前值,
否则做加法来得到整数结果。
以下为java代码实现:
public static int romanToInt(String s) {
char [] temp=s.toCharArray();
int res=0;
//注意从低位开始取
switch(temp[s.length()-1])
{
case 'I': res=res+1; break;
case 'V': res=res+5; break;
case 'X': res=res+10; break;
case 'L' :res=res+50; break;
case 'C': res=res+100; break;
case 'D': res=res+500; break;
case 'M': res=res+1000; break;
}
for(int i=s.length()-2;i>=0;i--)
{
switch(temp[i])
{
case 'I':
if(temp[i+1]=='V'||temp[i+1]=='X')res=res-1;
else res=res+1;
break;
case 'V':
res=res+5;
break;
case 'X':
if(temp[i+1]=='L'||temp[i+1]=='C')res=res-10;
else res=res+10;
break;
case 'L':
res=res+50;
break;
case 'C':
if(temp[i+1]=='D'||temp[i+1]=='M')res=res-100;
else res=res+100;
break;
case 'D':
res=res+500;
break;
case 'M':
res=res+1000;
break;
}
}
return res;
}
提交通过,,这是我第一次提交就通过了的,即使它的等级是简单,还是留下了激动的泪水。以下是评估结果。
关于内存的使用,感觉自己还没获取其中的精髓,没有找到有效节省内存的方法,继续探索吧。今日感悟:永远在路上,不要停止追逐更好的自己。共勉。(python版本下次一定)。