應用題 從羅馬數字轉成阿拉伯數字 Leetcode 13: Roman to Integer

閱讀時間約 4 分鐘

這題的題目在這裡:

題目會給定我們一組羅馬數字,要求我們把它轉換為對應十進位表示法的阿拉伯數字。


測試範例

Example 1:

Input: s = "III"
Output: 3
Explanation: III = 3.

Example 2:

Input: s = "LVIII"
Output: 58
Explanation: L = 50, V= 5, III = 3.

Example 3:

Input: s = "MCMXCIV"
Output: 1994
Explanation: M = 1000, CM = 900, XC = 90 and IV = 4.

約束條件

Constraints:

  • 1 <= s.length <= 15
  • s contains only the characters ('I', 'V', 'X', 'L', 'C', 'D', 'M').
  • It is guaranteed that s is a valid roman numeral in the range [1, 3999].

演算法

把原本題目給的羅馬數字和十進位數字的關係建立成一張映射表(字典)。

Symbol       Value
I 1
V 5
X 10
L 50
C 100
D 500
M 1000

遇到對應的符號,就把對應的十進位數字做相加。

唯一一個實作的細節是,遇到逆序排列(小的羅馬數字在前,大的羅馬數字在後)的情況時,要記得把小的那項*2補扣掉

例如,遇到IV時,IV是逆續,所以要把比較小的那項I*2補扣掉

IV = 10 + 50 - 2*10 = 60 - 20 = 40


程式碼

class Solution:
 def romanToInt(self, s: str) -> int:
  
  # key: roman symbol
  # value: decimal value
  mapping_table = {
       'I': 1,
       'V': 5,
       'X': 10,
       'L': 50,
       'C': 100,
       'D': 500,
       'M': 1000
      }
  
  # integer value
  number = 0
  
  # scan each roman symbol
  for idx, char in enumerate(s):
   
   # add corresponding value
   number += mapping_table[char]
   
   if idx and ( mapping_table[char] > mapping_table[ s[idx-1] ] ):
    
    # adjustment for IV, IX, XL, XC, CD, CM
    number -= 2 * mapping_table[ s[idx-1] ]
    
  
  return number



複雜度分析

時間複雜度: O( n)
從左到右,每個羅馬數字掃描過一遍。

空間複雜度: O(1)
都是臨時變數,所占用的記憶體空間為常數級別O(1)


關鍵知識點

想到用字典(雜湊映射表),去儲存每個羅馬數字和十進位表示裡面對應到的阿拉伯數字的映射關係。

另外,還有一個實作的細節是,遇到逆序排列(小羅馬數字的在前,大的羅馬數字在後)的情況時,要記得把小的那項*2補扣掉


Reference:

[1] Python O(n) by dictionary and math [w/ Hint] - Roman to Integer - LeetCode

52會員
340內容數
由有業界實戰經驗的演算法工程師, 手把手教你建立解題的框架, 一步步寫出高效、清晰易懂的解題答案。 著重在讓讀者啟發思考、理解演算法,熟悉常見的演算法模板。 深入淺出地介紹題目背後所使用的演算法意義,融會貫通演算法與資料結構的應用。 在幾個經典的題目融入一道題目的多種解法,或者同一招解不同的題目,擴展廣度,並加深印象。
留言0
查看全部
發表第一個留言支持創作者!
你可能也想看
0926如何解決「數學應用問題」亂寫 昨天進行一個小考,來檢視學生學習的成效如何。發現,應用問題有「亂寫」狀況。「亂寫」,只是表示學生寫錯,不是計算錯誤那種類型,而是被除數跟除數搞錯。 心想著,除了重新檢討這個數學問題的意思之外,還有什麼是老師可以做的,來幫助學生更能理解數學。晚上睡前,就胡思亂想了起來。
avatar
Injay Haung
2023-09-25
題目:AI在生活中的應用和介紹幾款AI的APAI的簡介:人工智能(Artificial Intelligence,簡稱AI)已經深入我們的日常生活,改變了我們的生活方式,並為我們帶來了更多便利。這篇文章將探討人工智能在生活中的多個應用,並簡單介紹幾款具有代表性的AI應用程序,讓你更了解這項令人振奮的AI技術。
Thumbnail
avatar
莊智涵
2023-08-28
ChatGPT出世後的反思:課堂上的提問技巧與應用在ChatGPT橫空出世的當下😮,如何提一個好問題或是下一個好指令,成為人們的新技能🎯,但是身為老師的您,真的會問好問題嗎🤔?還有良好的提問技巧您掌握住了嗎🎓? 在課堂上,問題提問是一個重要的環節,有助於引導學生思考和參與🌟。 以下是一些常用的提問公式,以及在課堂上的應用和範例📚。
Thumbnail
avatar
小豬老師
2023-04-30
國中會考國文科解題策略分析~(四.五)、詞性判斷在試題當中的應用雖然純詞性類已經淡出了會考選擇題的出題舞台,但在我的系統裡,詞性卻是重要的「解題武器」之一;這個武器的優勢是,他不是用事先背起來的、而是可以現場判斷,只要多加練習,有些題目「不用知道答案,也可以得分」。
Thumbnail
avatar
教國文的
2023-04-08
【OpenAI 應用】ChatGPT 震驚全球!取代人類新聞標題寫手,究竟有多強?在台灣,常常使用含糊不清且引人注目的方式以吸引眼球,這現象在 Wikipedia 的「台灣媒體亂象」一頁也有特別說明。 那麼,ChatGPT能否替代人類新聞標題寫手,並具有多強的能力呢?本文將深入探討。
Thumbnail
avatar
Logan
2023-02-06
AIoT數位轉型的法律議題(6)智慧機器人應用法制議題本文主要在講述人工智慧(Artificial Intelligence, AI)機器人風險管控的趨勢與研析,涉及每個國家的競爭力,尤其與AI機器人的政策與法制規範。
Thumbnail
avatar
建佑律師_NoMoreLaw
2021-08-17
應用金字塔原理的MECE原則來歸納分析問題聽見能量、聽見方法,聽見聲音在說話! Hi 你今天過的好嗎?我是雷恩。 在生活或工作中,我們常常會遇到複雜繁瑣的問題需要解決。而在我們面對各類不同的問題時,要如何看透問題的本質,精準地解決問題呢? 這個時候,我們可以利用 MECE 原則來幫助我們。
Thumbnail
avatar
RyanSay
2021-05-21
怎麼用英日文把話題先止住,以後再講?有時遇到對方喋喋不休,你很想拿一塊布把對方的嘴塞起來。或者你當下很忙,實在沒時間聽對方講話。這時候你會說「我們先停一下晚點再講好不好?」英日文會怎麼說呢?
Thumbnail
avatar
你的英日語自學導師 譯難忘  ོꦿ༄꧁꧂
2021-04-19
解『我想改變』這數學應用題:3個邏輯9個方法 改變讓你變更優秀,誰不想啊,可【改變真難】!難在你沒有『對方法』讓改變變得【好玩】、【輕鬆做到】 為甚麼老是改不了? 人是一種感性為主的動物,在人的大腦住了兩個象,1是大象,2是騎象人,大象是感性的,騎象人是理性。 當你要選擇時 這兩個象在看甜品吃/不吃,流口水的大象告訢自己:快拿起來吃啊
Thumbnail
avatar
LilyG莉莉兒
2021-01-27