热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

罗马数字转整数之代码优化

代码优化前言一、案例二、题解1、正向遍历2、反向遍历总结参考文献前言除了一题多解,打开视野之外;同一解法的不同角度也会导致程序的运行时间不同ÿ

代码优化

  • 前言
  • 一、案例
  • 二、题解
    • 1、正向遍历
    • 2、反向遍历
  • 总结
  • 参考文献


前言

除了一题多解,打开视野之外;同一解法的不同角度也会导致程序的运行时间不同,多了解多练习其它思路,打开优化代码的大门。

一、案例

在这里插入图片描述

二、题解

1、正向遍历

理清思路就行,用代码把简单思路表达出来就行。
遍历s的每一个字符做相应数字的加法即可;有一种特殊情况:当前值小于下一个值,则需特殊处理。

//罗马数字转整数
public class RomanToInt {//常规思路//遍历s的每一个字符做相应数字的加法即可&#xff1b;//有一种特殊情况&#xff1a;当前值小于下一个值&#xff0c;则需特殊处理。final static Map<Character, Integer> hash;static {hash &#61; new HashMap<>();hash.put(&#39;I&#39;, 1);hash.put(&#39;V&#39;, 5);hash.put(&#39;X&#39;, 10);hash.put(&#39;L&#39;, 50);hash.put(&#39;C&#39;, 100);hash.put(&#39;D&#39;, 500);hash.put(&#39;M&#39;, 1000);}public int romanToInt(String s) {char[] arr &#61; s.toCharArray();int len &#61; arr.length;int res &#61; 0;for (int i &#61; 0; i < len; ) {int val &#61; hash.get(arr[i]);int next &#61; i &#61;&#61; len - 1 ? 0 : hash.get(arr[i &#43; 1]);if (val >&#61; next) {res &#43;&#61; val;&#43;&#43;i;continue;}res &#43;&#61; next - val;i &#43;&#61; 2;}return res;}
}

2、反向遍历

反向遍历可以优化代码。
遇到比pre小的就减&#xff0c;否则就加&#xff1b;逻辑简单清晰。(在该思路的基础上。)

//如果从后往前遍历&#xff0c;可以省去一些选择模块&#xff0c;让其它情况能够做到尽量统一&#xff0c;简化代码&#xff0c;也降低了运行时间&#xff1b;
//遇到比pre小的就减&#xff0c;否则就加&#xff1b;逻辑简单清晰。(在该思路的基础上。)
class RomanToInt2 {//遍历s的每一个字符做相应数字的加法即可&#xff1b;有一种特殊情况&#xff1a;当前值小于下一个值&#xff0c;则需特殊处理。final static Map<Character, Integer> hash;static {hash &#61; new HashMap<>();hash.put(&#39;I&#39;, 1);hash.put(&#39;V&#39;, 5);hash.put(&#39;X&#39;, 10);hash.put(&#39;L&#39;, 50);hash.put(&#39;C&#39;, 100);hash.put(&#39;D&#39;, 500);hash.put(&#39;M&#39;, 1000);}public int romanToInt(String s) {char[] arr &#61; s.toCharArray();int len &#61; arr.length;int res &#61; 0, pre &#61; 0;for (int i &#61; len - 1; i >&#61; 0; i--) {int val &#61; hash.get(arr[i]);res &#43;&#61; val < pre ? -val : val;pre &#61; val;}return res;}
}

总结

1&#xff09;除了一题多解&#xff0c;打开视野之外&#xff1b;同一解法的不同方向也会导致程序的运行时间不同&#xff0c;多了解多练习其它思路&#xff0c;打开优化代码的大门。

参考文献

[1]LeetCode 罗马数字转整数


推荐阅读
  • Java中包装类的设计原因以及操作方法
    本文主要介绍了Java中设计包装类的原因以及操作方法。在Java中,除了对象类型,还有八大基本类型,为了将基本类型转换成对象,Java引入了包装类。文章通过介绍包装类的定义和实现,解答了为什么需要包装类的问题,并提供了简单易用的操作方法。通过本文的学习,读者可以更好地理解和应用Java中的包装类。 ... [详细]
  • Java太阳系小游戏分析和源码详解
    本文介绍了一个基于Java的太阳系小游戏的分析和源码详解。通过对面向对象的知识的学习和实践,作者实现了太阳系各行星绕太阳转的效果。文章详细介绍了游戏的设计思路和源码结构,包括工具类、常量、图片加载、面板等。通过这个小游戏的制作,读者可以巩固和应用所学的知识,如类的继承、方法的重载与重写、多态和封装等。 ... [详细]
  • SpringBoot uri统一权限管理的实现方法及步骤详解
    本文详细介绍了SpringBoot中实现uri统一权限管理的方法,包括表结构定义、自动统计URI并自动删除脏数据、程序启动加载等步骤。通过该方法可以提高系统的安全性,实现对系统任意接口的权限拦截验证。 ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • JavaSE笔试题-接口、抽象类、多态等问题解答
    本文解答了JavaSE笔试题中关于接口、抽象类、多态等问题。包括Math类的取整数方法、接口是否可继承、抽象类是否可实现接口、抽象类是否可继承具体类、抽象类中是否可以有静态main方法等问题。同时介绍了面向对象的特征,以及Java中实现多态的机制。 ... [详细]
  • Spring特性实现接口多类的动态调用详解
    本文详细介绍了如何使用Spring特性实现接口多类的动态调用。通过对Spring IoC容器的基础类BeanFactory和ApplicationContext的介绍,以及getBeansOfType方法的应用,解决了在实际工作中遇到的接口及多个实现类的问题。同时,文章还提到了SPI使用的不便之处,并介绍了借助ApplicationContext实现需求的方法。阅读本文,你将了解到Spring特性的实现原理和实际应用方式。 ... [详细]
  • 个人学习使用:谨慎参考1Client类importcom.thoughtworks.gauge.Step;importcom.thoughtworks.gauge.T ... [详细]
  • [大整数乘法] java代码实现
    本文介绍了使用java代码实现大整数乘法的过程,同时也涉及到大整数加法和大整数减法的计算方法。通过分治算法来提高计算效率,并对算法的时间复杂度进行了研究。详细代码实现请参考文章链接。 ... [详细]
  • 开发笔记:Java是如何读取和写入浏览器Cookies的
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了Java是如何读取和写入浏览器Cookies的相关的知识,希望对你有一定的参考价值。首先我 ... [详细]
  • 先看官方文档TheJavaTutorialshavebeenwrittenforJDK8.Examplesandpracticesdescribedinthispagedontta ... [详细]
  • JDK源码学习之HashTable(附带面试题)的学习笔记
    本文介绍了JDK源码学习之HashTable(附带面试题)的学习笔记,包括HashTable的定义、数据类型、与HashMap的关系和区别。文章提供了干货,并附带了其他相关主题的学习笔记。 ... [详细]
  • 模板引擎StringTemplate的使用方法和特点
    本文介绍了模板引擎StringTemplate的使用方法和特点,包括强制Model和View的分离、Lazy-Evaluation、Recursive enable等。同时,还介绍了StringTemplate语法中的属性和普通字符的使用方法,并提供了向模板填充属性的示例代码。 ... [详细]
  • 本文详细介绍了Java中vector的使用方法和相关知识,包括vector类的功能、构造方法和使用注意事项。通过使用vector类,可以方便地实现动态数组的功能,并且可以随意插入不同类型的对象,进行查找、插入和删除操作。这篇文章对于需要频繁进行查找、插入和删除操作的情况下,使用vector类是一个很好的选择。 ... [详细]
  • Java学习笔记之面向对象编程(OOP)
    本文介绍了Java学习笔记中的面向对象编程(OOP)内容,包括OOP的三大特性(封装、继承、多态)和五大原则(单一职责原则、开放封闭原则、里式替换原则、依赖倒置原则)。通过学习OOP,可以提高代码复用性、拓展性和安全性。 ... [详细]
  • 本文介绍了iOS数据库Sqlite的SQL语句分类和常见约束关键字。SQL语句分为DDL、DML和DQL三种类型,其中DDL语句用于定义、删除和修改数据表,关键字包括create、drop和alter。常见约束关键字包括if not exists、if exists、primary key、autoincrement、not null和default。此外,还介绍了常见的数据库数据类型,包括integer、text和real。 ... [详细]
author-avatar
阳光ai星星
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有