leetcode算法题--罗马数字转整数(C语言实现)

题目描述:

在这里插入图片描述

范例:

在这里插入图片描述
思路分析:根据题目描述以及范例在C语言的里面我们可以想到switch循环,对每个符就是不同的case,赋予不同的数值,但是,对于有规律的字符串switch并不能更好的处理,因此需要分若干类,如若某个字符是I,下一个是V,则需要进行对应的不同的运算。

代码分析:



#include<stdio.h>
//#include <stdlib.h>
int RomanToInt(char *s) {
    int a=0,i=0;
    while(s[i]!='\0') {
        if (s[i] == 'I' && s[i+1] == 'V') {
            a += 4;
            i++;//每个if语句都要i自增,避免死循环
        }
        else if(s[i]=='I'&&s[i+1]=='X'){
            a+=9;
            i++;
        }
        else if(s[i]=='X'&&s[i+1]=='L'){
            a+=40;
            i++;
        }
        else if(s[i]=='X'&&s[i+1]=='C'){
            a+=90;
            i++;
        }
        else  if(s[i]=='C'&&s[i+1]=='D'){
            a+=400;
            i++;//每一次计数器都要计数不然会进入死循环
        }
        else if(s[i]=='C'&&s[i+1]=='M'){
            a+=900;
            i++;
        }
        else{
            switch(s[i]){
                case 'I':a+=1;break;
                case 'V':a+=5;break;
                case 'X':a+=10;break;
                case 'L':a+=50;break;
                case 'C':a+=100;break;
                case 'D':a+=500;break;
                case 'M':a+=1000;break;
            }
            i++;
        }
    }
    return a;
}
int main(){
    char string[10000];
    gets(string);
    RomanToInt(string);
    printf("转变之后的数字:%d",RomanToInt(string));
    return 0;
}

心得分析:虽然这不是最好的办法,但是容易想到,并且代码比较好实现。

如果你们有好的办法,记得说一下哦!观看了,麻烦点个赞哦!

题目来源:https://leetcode-cn.com/problems/roman-to-integer/

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值