摘要:阿拉伯?dāng)?shù)字轉(zhuǎn)換成羅馬數(shù)字給出一個(gè)阿拉伯?dāng)?shù)字,返回此數(shù)字的羅馬數(shù)字表示思路用表記錄關(guān)鍵的羅馬數(shù)字和阿拉伯?dāng)?shù)字,將輸入循環(huán)除以,,這些關(guān)鍵數(shù)字,余數(shù)為,將對(duì)應(yīng)的羅馬字符串加次看到大神的思路,也是查表,但更加精妙,將數(shù)字分解為千位,百位,十位和個(gè)
阿拉伯?dāng)?shù)字轉(zhuǎn)換成羅馬數(shù)字 Integer to Roman
給出一個(gè)阿拉伯?dāng)?shù)字,返回此數(shù)字的羅馬數(shù)字表示
Given an integer, convert it to a roman numeral.
Input is guaranteed to be within the range from 1 to 3999.
example 1
input: CCCLXXXIX output: 389思路
用表記錄關(guān)鍵的羅馬數(shù)字和阿拉伯?dāng)?shù)字,將輸入循環(huán)除以1000,900,500 ... 這些關(guān)鍵數(shù)字,余數(shù)為y,將對(duì)應(yīng)的羅馬字符串加y次
看到大神的思路,也是查表,但更加精妙,將數(shù)字分解為千位,百位,十位和個(gè)位,然后查表將字符串相加,很神奇的思路,剛看到的時(shí)候驚嘆了一下,代碼如下
代碼class Solution(object): # 思路1 def intToRoman1(self, num): """ :type num: int :rtype: str """ arabic = [1000, 900, 500, 400, 100, 90, 50, 40, 10, 9, 5, 4, 1] roman = ["M", "CM", "D", "CD", "C", "XC", "L", "XL", "X", "IX", "V", "IV", "I"] ret = "" i = 0 while num: yu = num // arabic[i] ret += roman[i] * yu num = num - yu * arabic[i] i += 1 return ret # 神奇的思路2 def intToRoman2(self, num): M = ["", "M", "MM", "MMM"] #0, 1000, 2000, 3000 C = ["", "C", "CC", "CCC", "CD", "D", "DC", "DCC", "DCCC", "CM"] #0, 100, 200, ... , 900 X = ["", "X", "XX", "XXX", "XL", "L", "LX", "LXX", "LXXX", "XC"] #0, 10, 20, ... , 90 I = ["", "I", "II", "III", "IV", "V", "VI", "VII", "VIII", "IX"] #0, 1, 2, ... , 9 return M[num // 1000] + C[(num % 1000) // 100] + X[(num % 100) // 10] + I[num % 10]
本題以及其它leetcode題目代碼github地址: github地址
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://m.hztianpu.com/yun/38672.html
摘要:下面分幾步來簡單的探探不同類型的轉(zhuǎn)換吧以下的內(nèi)容,都可以從權(quán)威指南中找到。其他值轉(zhuǎn)換成在編寫代碼的過程中,幾乎不用考慮它的取值類型。核心內(nèi)置類,會(huì)嘗試先于可以理解為對(duì)象優(yōu)先轉(zhuǎn)換成數(shù)字例外的是,利用的是轉(zhuǎn)換。 最近在寫公司的登錄注冊(cè)模塊,遇到類型不同相比較的時(shí)候,就心驚膽戰(zhàn),每次都要用瀏覽器來驗(yàn)證一下,決定亂七八糟的隨便寫一下,方便日后自己回顧知識(shí)~ 弱類型帶來的那些讓人迷糊的事 弱類型...
摘要:數(shù)字加轉(zhuǎn)為,再做加法運(yùn)算。在這里,被解析成一個(gè)空的因此實(shí)際上解析成這樣就是把一個(gè)空數(shù)組轉(zhuǎn)換成數(shù)值,調(diào)用之后還是自身,因此調(diào)用得到一個(gè)空字符串,轉(zhuǎn)換成數(shù)字。參考詳解的加法運(yùn)算符中和的返回值情況是怎樣的 JavaScript 里面不同的類型做加法之前,需要做各種轉(zhuǎn)換,這里做一個(gè)比較完善的總結(jié)。 基本轉(zhuǎn)換規(guī)則 運(yùn)算雙方存在對(duì)象時(shí) 如果有一個(gè)對(duì)象,那么先把它轉(zhuǎn)換成基本類型值 轉(zhuǎn)換之后,如...
摘要:羅馬數(shù)字轉(zhuǎn)換成阿拉伯?dāng)?shù)字給出一個(gè)羅馬數(shù)字字符串,返回此數(shù)字的阿拉伯?dāng)?shù)字思路存儲(chǔ)單個(gè)羅馬字母代表的阿拉伯?dāng)?shù)字初始狀態(tài),循環(huán)遍歷字符串,如果所代表的阿拉伯?dāng)?shù)字大于的,則加到上,如果小于,則減去代表的阿拉伯?dāng)?shù)字代碼右邊界保證不會(huì)下標(biāo)越界本 羅馬數(shù)字轉(zhuǎn)換成阿拉伯?dāng)?shù)字 Roman to integer 給出一個(gè)羅馬數(shù)字(字符串),返回此數(shù)字的阿拉伯?dāng)?shù)字(int) Given a roman n...
摘要:核心內(nèi)置類,會(huì)嘗試先于可以理解為對(duì)象優(yōu)先轉(zhuǎn)換成數(shù)字例外的是,利用的是轉(zhuǎn)換。非核心的對(duì)象,通過自己的實(shí)現(xiàn)中定義的方法轉(zhuǎn)換成原始值。 本文首發(fā)于個(gè)人博客 showImg(https://segmentfault.com/img/remote/1460000015954811?w=639&h=724); 看到這個(gè)是不是有一種想打人的感覺,垃圾 JavaScript,這特么都什么鬼,相信很多...
閱讀 2482·2021-11-25 09:43
閱讀 1309·2021-11-24 09:39
閱讀 825·2021-11-23 09:51
閱讀 2450·2021-09-07 10:18
閱讀 1971·2021-09-01 11:39
閱讀 2837·2019-08-30 15:52
閱讀 2648·2019-08-30 14:21
閱讀 2916·2019-08-29 16:57