leetcode 12題 數字轉羅馬數字
答案一:我的**
1class
solution
14 index=0;15
for(int i=5;i<=500;i*=10)19
20//
通過雜湊表和取餘數來進行倒序獲取羅馬字元
21string
s,re;
22int temp=num;
23int cnt=1
;24 index=0;25
while(temp>0)29
else
if(pop==9
)else
if(pop==4
)else
41for(int i=0;i)
44if(flag==1)47
}48 cnt=cnt*10;49
}50//cout<51
for(int i=0;i)
54return
re;55
}56 };
答案二:
參考別人將預先的特殊情況(即羅馬數字符號進製與羅馬數字前後大小顛倒兩種情況全部事先儲存起來,然後根據實際情況進行計算)
classsolution ;
vector
rom=;
int i=0
;
string re=""
;
for(int i=0;i)
}return
re; }
};
LeetCode12 整數轉羅馬數字
題目大意 將乙個1到3999範圍內的整數轉為羅馬數字 題目分析 首先熟悉轉換規則,然後可以使用兩個list儲存對應的對映關係,然後每次從大到小看num是否大於1000,大於900,大於500,若在某個區間的話,就將羅馬數字加進來,num減去相應的數值,直到num為0 展示 class solutio...
Leetcode 12 整數轉羅馬數字
題目 羅馬數字包含以下七種字元 i,v,x,l,c,d和m。字元 數值 i 1 v 5 x 10 l 50 c 100 d 500 m 1000例如,羅馬數字 2 寫做ii,即為兩個並列的 1。12 寫做xii,即為x ii。27 寫做xxvii,即為xx v ii。通常情況下,羅馬數字中小的數字在...
LeetCode 12 整數轉羅馬數字
題目鏈結 題目描述 羅馬數字包含以下七種字元 i,v,x,l,c,d 和 m。字元 數值 i 1 v 5 x 10 l 50 c 100 d 500 m 1000例如,羅馬數字 2 寫做 ii 即為兩個並列的 1。12 寫做 xii 即為 x ii 27 寫做 xxvii,即為 xx v ii 通常...