面试经典150题——罗马数字转整数

embedded/2024/10/18 14:25:04/

面试经典150题 day17

      • 题目来源
      • 我的题解
        • 方法一 哈希表
        • 方法二 优化版本

题目来源

力扣每日一题;题序:13

我的题解

方法一 哈希表

存储单独的存在的可能字符串

时间复杂度:O(n)
空间复杂度:O©。C表示单独存在的可能字符串数量

java">public int romanToInt(String s) {Map<String,Integer> map=new HashMap<>();map.put("I",1);map.put("IV",4);map.put("V",5);map.put("IX",9);map.put("X",10);map.put("XL",40);map.put("L",50);map.put("XC",90);map.put("C",100);map.put("CD",400);map.put("D",500);map.put("CM",900);map.put("M",1000);int res=0;for(int i=0;i<s.length();){if(i<s.length()-1&&map.containsKey(s.substring(i,i+2))){res+=map.get(s.substring(i,i+2));i+=2;}else{int cur=map.get(s.substring(i,i+1));res+=cur;i++;}}return res;
}
方法二 优化版本

实际存储map时不需要存储String类型,方法一为了存储像“IV”、“VX”这种比较特别的值,导致需要使用String来存储。方法二不再存储特殊的值,因此转为使用Character类型进行存储。只需要判断s中相邻两个字符对应的值的差是否是4或者9的倍数,若后一个字符的数字值大于前一个字符的数字值,并且差值是4或者9的倍数,这两个相邻的字符将组成一个罗马数字。

时间复杂度:O(n)
空间复杂度:O(K)。

java">public int romanToInt(String s) {Map<Character,Integer> map=new HashMap<>();map.put('I',1);map.put('V',5);map.put('X',10);map.put('L',50);map.put('C',100);map.put('D',500);map.put('M',1000);int res=0;char[] data=s.toCharArray();int i=0;for(;i<data.length-1;i++){int num1=map.get(data[i]);int num2=map.get(data[i+1]);if((num2-num1)>0&&((num2-num1)%4==0||(num2-num1)%9==0)){res+=num2-num1;i++;}else{res+=num1;}}if(i==data.length-1)res+=map.get(data[i]);return res;
}

有任何问题,欢迎评论区交流,欢迎评论区提供其它解题思路(代码),也可以点个赞支持一下作者哈😄~


http://www.ppmy.cn/embedded/20834.html

相关文章

Leetcode 17. 电话号码的字母组合

给定一个仅包含数字 2-9 的字符串&#xff0c;返回所有它能表示的字母组合。答案可以按 任意顺序 返回。 给出数字到字母的映射如下&#xff08;与电话按键相同&#xff09;。注意 1 不对应任何字母。 示例 1&#xff1a; 输入&#xff1a;digits “23” 输出&#xff1a;[“a…

28.Gateway-网关过滤器

GatewayFilter是网关中提供的一种过滤器&#xff0c;可以多进入网关的请求和微服务返回的响应做处理。 GatewayFilter(当前路由过滤器&#xff0c;DefaultFilter) spring中提供了31种不同的路由过滤器工厂。 filters针对部分路由的过滤器。 default-filters针对所有路由的默认…

C#多线程之(Thread)详解与示例

文章目录 一、线程的基本概念二、C#中创建和启动线程的方法三、线程的生命周期四、线程的状态转换五、线程之间的通信机制六、线程安全的编程实践使用 ConcurrentBag 进行线程安全的数据收集 总结 本文将深入探讨C#多线程编程的核心概念&#xff0c;包括线程的基本概念、创建和…

探索HSE化工安全系统在化工生产中的作用

在现代工业化生产中&#xff0c;化工企业扮演着至关重要的角色&#xff0c;但与此同时&#xff0c;化工安全问题也备受关注。为了保障生产环境的安全&#xff0c;HSE化工安全系统应运而生。本文将详细介绍HSE化工安全系统的功能和优势&#xff0c;让您深入了解其在工业生产中的…

故障诊断 | 基于GASF-CNN的状态识别研究

概述 抗蛇行减振器作为高速动车组二系悬挂系统的关键零部件,对改善车辆运动稳定性、提高车辆系统的临界速度具有重要意义。抗蛇行减振器在高级修时需全部进行拆解维修或报废处理,若在高级修中的三、四级修时其性能尚能够满足实际使用要求,将其过早地拆解检修或者报废换新无…

短信视频提取批量工具,免COOKIE,博主视频下载抓取,爬虫

痛点&#xff1a;关于看了好多市面的软件&#xff0c;必须要先登录自己的Dy号才能 然后找到自己的COOKIE 放入软件才可以继续搜索&#xff0c;并且无法避免长时间使用 会导致无法正常显示页面的问题。 有没有一种方法 直接可以使用软件&#xff0c;不用设置的COOKIE的方法呢 …

Gradio 最快创建Web 界面部署到服务器并演示机器学习模型,本文提供教学案例以及部署方法,避免使用繁琐的django

最近学习hugging face里面的物体检测模型&#xff0c;发现一个方便快捷的工具&#xff01; Gradio 是通过友好的 Web 界面演示机器学习模型的最快方式&#xff0c;以便任何人都可以在任何地方使用它&#xff01; 一、核心优势&#xff1a; 使用这个开发这种演示机器学习模型的…

Cookie,Session,Token

什么是 Cookie 和 Session 和Token? 什么是 Cookie HTTP Cookie&#xff08;也叫 Web Cookie或浏览器 Cookie&#xff09;是服务器发送到用户浏览器并保存在本地的一小块数据&#xff0c;它会在浏览器下次向同一服务器再发起请求时被携带并发送到服务器上。通常&#xff0c;…