Leetcode 13.罗马数字转整数

题目意在对数组的快速查找

思路:哈希表

首先创建哈希表,对字符以及对应的数据进行输入,当下一个字符小于或等于当前字符时,进行累加,否则减去当前字符的值

cpp 复制代码
class Solution {
public:
    int romanToInt(string s) {
        unordered_map<char,int>luoma{
        {'I', 1},
        {'V', 5},
        {'X', 10},
        {'L', 50},
        {'C', 100},
        {'D', 500},
        {'M', 1000},
        };
        int sum=0;
        for(int i=0;i<s.size();i++){
            if(i < s.size() - 1 &&luoma[s[i+1]]>luoma[s[i]])sum-=luoma[s[i]];
            else sum+=luoma[s[i]];
        }
        return sum;
    }
};

注意:要判断是否越界以及ASCII值和哈希表中数值对应的区分

在这里直接用s[i]对应的是哈希表中的键(unordered_map<KeyType, ValueType> variableName),也就是第一个

完整代码(参考)

cpp 复制代码
#include <iostream>
#include <string>
#include <unordered_map>

using namespace std;


    int romanToInt(string s) {
        unordered_map<char, int> luoma = {
            {'I', 1},
            {'V', 5},
            {'X', 10},
            {'L', 50},
            {'C', 100},
            {'D', 500},
            {'M', 1000},
        };
        int sum = 0;
        for (int i = 0; i < s.size(); i++) {
            if (i < s.size() - 1 && luoma[s[i + 1]] > luoma[s[i]]) {
                sum -= luoma[s[i]]; 
            } else {
                sum += luoma[s[i]]; 
            }
        }
        return sum;
    }


int main() {

    string roman;
    cin >> roman; 

    cout <<romanToInt(roman)<< endl; 

    return 0;
}
相关推荐
小雅痞17 分钟前
[Java][Leetcode middle] 3. 无重复字符的最长子串
java·开发语言·leetcode
qeen8721 分钟前
【算法笔记】简单贪心
c++·笔记·算法·贪心算法
逻辑驱动的ken28 分钟前
Java高频面试考点场景题21
java·开发语言·面试·职场和发展·求职招聘
ting945200032 分钟前
动手学深度学习(PyTorch版)深度详解(10): 优化算法 全解
人工智能·pytorch·深度学习·算法
ulias2121 小时前
leetcode热题 - 5
数据结构·算法·leetcode
Funny_AI_LAB1 小时前
Naval最新播客谈“氛围编码”:Vibe Coding 开启“一人独角兽”时代
人工智能·算法·语言模型·agi
如何原谅奋力过但无声1 小时前
【灵神高频面试题合集04-05】二分查找
数据结构·python·算法·leetcode
我不是懒洋洋1 小时前
【数据结构】排序算法(直接插入排序、希尔排序、选择排序、堆排序、冒泡排序、快速排序、归并排序、计数排序)
c语言·数据结构·c++·经验分享·算法·排序算法
MediaTea1 小时前
ML:逻辑回归的基本原理与实现
人工智能·算法·机器学习·数据挖掘·逻辑回归
超级码力66610 小时前
【Latex文件架构】Latex文件架构模板
算法·数学建模·信息可视化