LeetCode进阶之路(Roman to Integer)

Given a roman numeral, convert it to an integer.

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

题目:把Roman数字转换成整型,范围是1-3999;

通过这个问题,发现自己一个很大的缺陷,碰到问题首先思考的是最简单的方法,然后就动手写,最后发现这种思路有很多bug,修修补补最终还是存在缺陷。这个Roman转整型就是一个很典型的例子,第一反应就是取出每一位的Roman数字,然后遍历Roman二维数组,得到对应的整型数字。

例如2304-MMCCCIV,取出来时MM、CCC、IV,但是2034取出来的也是同样如此。碰到题目一定到先把思路整理好,在动手,这样后期不用做太大的修改。另外一点,针对这种题目,一定要找一种简单的规律,切记切记。

public static int romanToInt(String s) {
		int ret = toNumber(s.charAt(0));
		for(int i = 1;i<s.length();i++){
			if(toNumber(s.charAt(i-1)) < toNumber(s.charAt(i))) {
				ret += toNumber(s.charAt(i)) - 2*toNumber(s.charAt(i-1));
			} else {
				ret += toNumber(s.charAt(i));
				}
			}
		return ret;

	}
	public static int toNumber(char ch) {
	
			switch (ch) {
				case 'M':return 1000;
				case 'C':return 100;
				case 'X':return 10;
				case 'I':return 1;
				case 'V':return 5;
				case 'L':return 50;
				case 'D':return 500;
			}
			return ch;
	}



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值