码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Leetcode13. 罗马数字转整数


    力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台

    罗马数字包含以下七种字符: I, V, X, L,C,D 和 M。

    字符          数值
    I             1
    V             5
    X             10
    L             50
    C             100
    D             500
    M             1000

    例如, 罗马数字 2 写做 II ,即为两个并列的 1 。12 写做 XII ,即为 X + II 。 27 写做  XXVII, 即为 XX + V + II 。

    通常情况下,罗马数字中小的数字在大的数字的右边。但也存在特例,例如 4 不写做 IIII,而是 IV。数字 1 在数字 5 的左边,所表示的数等于大数 5 减小数 1 得到的数值 4 。同样地,数字 9 表示为 IX。这个特殊的规则只适用于以下六种情况:

    • I 可以放在 V (5) 和 X (10) 的左边,来表示 4 和 9。
    • X 可以放在 L (50) 和 C (100) 的左边,来表示 40 和 90。 
    • C 可以放在 D (500) 和 M (1000) 的左边,来表示 400 和 900。

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

    示例 1:

    输入: s = "III"
    输出: 3

    示例 2:

    输入: s = "IV"
    输出: 4

    代码如下:

    1. class Solution {
    2. public int romanToInt(String s) {
    3. if(s.length() == 0){
    4. return 0;
    5. }
    6. int sum = 0;
    7. int preNum = getValue(s.charAt(0));
    8. for(int i = 1; i < s.length();i++){
    9. int num = getValue(s.charAt(i));
    10. if(preNum < num){
    11. sum -= preNum;
    12. }
    13. else{
    14. sum += preNum;
    15. }
    16. preNum = num;
    17. }
    18. //for循环中加减的是当前遍历到的上一个值,所以退出循环后把最后一个值加上
    19. sum += preNum;
    20. return sum;
    21. }
    22. private int getValue(char ch){
    23. switch(ch){
    24. case 'I': return 1;
    25. case 'V': return 5;
    26. case 'X': return 10;
    27. case 'L': return 50;
    28. case 'C': return 100;
    29. case 'D': return 500;
    30. case 'M': return 1000;
    31. default : return 0;
    32. }
    33. }
    34. }

     

  • 相关阅读:
    Python自动化框架 【pytest 框架介绍】
    第一场面试
    electron+vue3全家桶+vite项目搭建【27】封装窗口工具类【1】雏形
    现代架构设计:构建可伸缩、高性能的系统
    HTML5 —— 初识 Canvas 画布
    手机资讯:华为Mate60 Pro上手体验三天的使用体验
    JDBC 简介
    Flink 集群部署模式
    痛定思痛学DP,动态规划的一般性应用流程的总结
    领导大规模敏捷 - Leading SAFe认证,SAFe认证Leading SAFe官方认证培训班
  • 原文地址:https://blog.csdn.net/neverSaynever_/article/details/133254695
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号