力扣 (LeetCode)-13. 罗马数字转整数
前言
❤️笔芯❤️~
栈,队列,链表,集合,字典和散列表,树,图
13. 罗马数字转整数
一、题目描述
罗马数字包含以下七种字符: I, V, X, L,C,D 和 M。
二、思路分析
- 罗马数字由
I,V,X,L,C,D,M
构成; - 当小值在大值的左边,则减小值,如
IV=5-1=4
- 当小值在大值的右边,则加小值,如
VI=5+1=6
- 由上可知,右值永远为正,因此最后一位必然为正
把一个小值放在大值的左边,就是做减法,否则为加法。
- 首先将所有的组合可能性列出并添加到哈希表中
- 然后对字符串进行遍历,由于组合只有两种,一种是
1
个字符,一种是2
个字符,其中2
个字符优先于1
个字符 - 先判断两个字符的组合在哈希表中是否存在,存在则将值取出加到结果
ans
中,并向后移2
个字符。不存在则将判断当前1
个字符是否存在,存在则将值取出加到结果ans
中,并向后移1
个字符 - 遍历结束返回结果
ans
三、答案代码
1 | var romanToInt = function(s) { |
四、总结
- 罗马数字转整数题解
回看笔者往期高赞文章,也许能收获更多喔!
- 一个合格的初级前端工程师需要掌握的模块笔记
- Vue.js笔试题解决业务中常见问题
- 【初级】个人分享Vue前端开发教程笔记
- 长篇总结之JavaScript,巩固前端基础
- 前端面试必备ES6全方位总结
- 达达前端个人web分享92道JavaScript面试题附加回答
- 【图文并茂,点赞收藏哦!】重学巩固你的Vuejs知识体系
- 【思维导图】前端开发-巩固你的JavaScript知识体系
- 14期-连肝7个晚上,总结了计算机网络的知识点!(共66条)
- 这是我的第一次JavaScript初级技巧
- localStorage和sessionStorage本地存储
- HTML5中的拖放功能
- 挑战前端知识点HTTP/ECMAScript
- 必学必会-音频和视频
- 前端170面试题+答案学习整理(良心制作)
- 前端HTML5面试官和应试者一问一答
- 哪吒闹海,席卷图文学习前端Flex布局
- 腾讯位置服务开发应用
- 【进阶】面试官问我Chrome浏览器的渲染原理(6000字长文)
- 面试官一上来就问我Chrome底层原理和HTTP协议(万字长文)
- 熬夜总结了 “HTML5画布” 的知识点
- this/call/apply/bind(万字长文)
- HTTP/HTTPS/HTTP2/DNS/TCP/经典题
- 执行上下文/作用域链/闭包/一等公民
- Web页面制作基础
- 学习总结之HTML5剑指前端(建议收藏,图文并茂)
❤️关注+点赞+收藏+评论+转发❤️,原创不易,鼓励笔者创作更好的文章
本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来自 写前端技术知识!
评论