当前位置: 首页 > news >正文

leetcode刷题日记——罗马数字转整数

[ 题目描述 ]:
在这里插入图片描述
[ 思路 ]:

  • 题目要求将一个给出的罗马数字表示的字符串转换为阿拉伯数字
  • 先判别 I、X、C三个字符能否与下一个字符组成新的数字
    • 能组成,则全部转换,下标向后移动两位
    • 不能组成,则转换当前字符,下标向后移动一位
  • 其余字符按照规则转换,没有技巧,全是暴力
  • 也可以用switch-case,代码结构会清晰点
  • 运行如下

在这里插入图片描述

int romanToInt(char* s) {
    int i=0,sum=0;
    while(s[i]!='\0'){
        if(s[i]=='I'){
            if(s[i+1]=='V'){
                sum+=4;
                i+=2;
            }else if(s[i+1]=='X'){
                sum+=9;
                i+=2;
            }else{
                i+=1;
                sum+=1;
            }
            continue;
        }
        if(s[i]=='X'){
            if(s[i+1]=='L'){
                sum+=40;
                i+=2;
            }else if(s[i+1]=='C'){
                sum+=90;
                i+=2;
            }else{
                i+=1;
                sum+=10;
            }
            continue;
        }
        if(s[i]=='C'){
            if(s[i+1]=='D'){
                sum+=400;
                i+=2;
            }else if(s[i+1]=='M'){
                sum+=900;
                i+=2;
            }else{
                i+=1;
                sum+=100;
            }
            continue;
        }
        if(s[i]=='V') sum+=5;
        if(s[i]=='L') sum+=50;
        if(s[i]=='D') sum+=500;
        if(s[i]=='M') sum+=1000;
        i++;
    }
    return sum;
}

[ 官方题解 ]:

  • 一、模拟
    • 通常情况下,罗马数字中小的数字在大的数字的右边。若输入的字符串满足该情况,那么可以将每个字符视作一个单独的值,累加每个字符对应的数值即可。
    • 若存在小的数字在大的数字的左边的情况,根据规则需要减去小的数字。对于这种情况,我们也可以将每个字符视作一个单独的值,若一个数字右侧的数字比它大,则将该数字的符号取反。
int romanToInt(char* s) {
    int symbolValues[26];
    symbolValues['I' - 'A'] = 1;
    symbolValues['V' - 'A'] = 5;
    symbolValues['X' - 'A'] = 10;
    symbolValues['L' - 'A'] = 50;
    symbolValues['C' - 'A'] = 100;
    symbolValues['D' - 'A'] = 500;
    symbolValues['M' - 'A'] = 1000;
    int ans = 0;
    int n = strlen(s);
    for (int i = 0; i < n; ++i) {
        int value = symbolValues[s[i] - 'A'];
        if (i < n - 1 && value < symbolValues[s[i + 1] - 'A']) {
            ans -= value;
        } else {
            ans += value;
        }
    }
    return ans;
}

相关文章:

  • 基于SpringBoot + HTML 的心理健康管理系统
  • PHY——LAN8720A 代码解析 (三)
  • HttpClient-01.介绍
  • Libevent UDP开发指南
  • 基于动态渲染与反检测技术的爬虫框架设计
  • Spring笔记05-面向切面编程
  • 每日一题(小白)暴力娱乐篇9
  • 【AI4CODE】4 Trae 锤一个数据搬运工的小应用
  • fpga:分秒计时器
  • 创建虚拟机
  • ChatGPT 的新图像生成器非常擅长伪造收据
  • 3dmax批量转glb/gltf/fbx/osgb/stl/3ds/dae/obj/skp格式导出转换插件,无需一个个打开max,材质贴图在
  • vue实现俄罗斯方块
  • MMD 转 STL,拓宽 3D 模型应用边界:方法与门道
  • 《JVM考古现场(十五):熵火燎原——从量子递归到热寂晶壁的代码涅槃》
  • 二分答案 + P8800 [蓝桥杯 2022 国 B] 卡牌 - 题解
  • 网络安全设备介绍:防火墙、堡垒机、入侵检测、入侵防御
  • UniApp集成极光推送详细教程
  • 多模态大语言模型arxiv论文略读(三)
  • Python - 爬虫-网页抓取数据-库urllib
  • 2025上海十大动漫IP评选活动启动
  • 印度杰纳布河上游两座水电站均已重新开闸
  • 司法部:持续规范行政执法行为,加快制定行政执法监督条例
  • 外交部:应美方请求举行贸易代表会谈,中方反对美滥施关税立场没有变化
  • 詹丹|高考语文阅读题设计和答案拟制的一些缺憾
  • 潘功胜:降准0.5个百分点,降低政策利率0.1个百分点