日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Roman to Integer - LeetCode

發布時間:2024/10/12 编程问答 35 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Roman to Integer - LeetCode 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

目錄

  • 題目鏈接
  • 注意點
  • 解法
  • 小結

題目鏈接

Roman to Integer - LeetCode

注意點

  • 大的數字在小的數字左邊是正常情況,要考慮的是小的數字在大的數字右邊的那8種情況

解法

解法一:從右至左,對于出現的每個字符逐個判斷,累加。時間復雜度為O(n)

class Solution { public:int romanToInt(string s) {int i,n = s.size(),anw = 0;for(i = n-1;i >= 0;i--){if(s[i] == 'M'){if(s[i-1] == 'C'){anw += 900;i--;}else{anw += 1000;}}else if(s[i] == 'D'){if(s[i-1] == 'C'){anw += 400;i--;}else{anw += 500;}}else if(s[i] == 'C'){if(s[i-1] == 'X'){anw += 90;i--;}else{anw += 100;}}else if(s[i] == 'L'){if(s[i-1] == 'X'){anw += 40;i--;}else{anw += 50;}}else if(s[i] == 'X'){if(s[i-1] == 'I'){anw += 9;i--;}else{anw += 10;}}else if(s[i] == 'V'){if(s[i-1] == 'I'){anw += 4;i--;}else{anw += 5;}}else if(s[i] == 'I'){anw += 1;}//printf("%d\n",anw);}return anw;} };

解法二:從左至右。如果之前的數字小于當前的就減去之前的數字,否則就加上。最后一個字符無論如何都加上。時間復雜度O(n)

class Solution { public:int romanToInt(string s) {map<char,int> m;m['I'] = 1;m['V'] = 5;m['X'] = 10;m['L'] = 50;m['C'] = 100;m['D'] = 500;m['M'] = 1000;int i,n = s.size(),anw = 0;int before = m[s[0]],now = 0;for(i = 1;i < n;i++){now = m[s[i]];if(before < now){anw -= before;}else{anw += before;}before = now;}anw += before;return anw;} };

小結

  • 理解了羅馬數字的原理這題就不難

轉載于:https://www.cnblogs.com/multhree/p/10320230.html

總結

以上是生活随笔為你收集整理的Roman to Integer - LeetCode的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。