LeetCode 13. Roman to Integer C语言

给定一个罗马数字,将其转换为整数。

输入保证在1到3999的范围内。

题目的意思给罗马数字,转成对应的数字,范围从1-3999;补充知识,下图是对应转换规则;



不过多的说废话:根据上图我们直接说一下解题思路:1。怎么解析罗马数字,需要我们自己做一些映射这里我写一个方法来做这项工作:int charToInt(char ch); 2。怎么把解析出来的罗马数字计算出来结果;我们需要观察出普遍的规律,才能用程序来实现;

如:“IV”,“VI”,“IX”,“MCMXCVI”,通过观察我们不难发现,当前字符转成的数字小于下一个字符所转成的数字,也就是说左边的小于右边的,如“IV”,这时候我们就后面的减去前面的; 这里注意,当你做完减法时候,也就是我们已经也把后面的字符计算完成了,所以你的指针就要索引++;反之,加上当前转出来的结果;具体实现,直接看代码吧!

直接贴出代码

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

int romanToInt(char* s) {
    if(s == NULL)
        return 0;
    int index = 0; // 索引
    int result = 0;// 最后输出结果
    while(s[index] !='\0'){
        if(charToInt(s[index]) < charToInt(s[index+1])){
            result += charToInt(s[index+1]) - charToInt(s[index]);
            index++;            
        }else{
            result += charToInt(s[index]) ;
        }
        index++;
    }
    return result;
}



  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值