/*
Convert a non-negative integer to its english words representation. Given input is guaranteed to be less than 2^31 - 1.
For example,
123 -> "One Hundred Twenty Three"
12345 -> "Twelve Thousand Three Hundred Forty Five"
1234567 -> "One Million Two Hundred Thirty Four Thousand Five Hundred Sixty Seven"
*/
/*
Thinking:
2^31 - 1 = 2147483647
2,147,483,647
1. 按照量級:Billion Million Thousand
2. 每個分割:Zero One Two Three Four Five Six Seven Eight Night (個位)
Ten Twenty Thirty Forty Fifty Sixty Seventy Eighty Ninety (十位)
(十位如果是1闽铐,則需要匹配10~19许赃,Ten古涧,Eleven误续,twelve绸吸,thirteen环疼,fourteen, fourteen, fifteen, sixteen, seventeen, eighteen, nineteen)
個位+Hundred (百位)
Step:
1. 先把整個數(shù)按 3 位劃分
2. 然后每個分割遇到 0 則不解析
3. 如果數(shù)值就是 0砌些,返回 Zero
按字符串來處理呜投,如果按整除來處理更快,每次除以1000則可以按3為進行分割了,
而且還可以過濾前面的0
*/
func convIntToEng(_ intNumber: Int) -> String {
guard intNumber > 0, intNumber <= 2147483647 else {
return "Zero"
}
var number = intNumber
var intArray: [Int] = []
while number > 0 {
//把余數(shù)放入到數(shù)組
let subInt = number % 1000
intArray.append(subInt)
number = number / 1000
}
//20~90
let tenStrings = ["Zero", "Ten", "Twenty", "Thirty", "Forty", "Fifty", "Sixty", "Seventy", "Eighty", "Ninety"]
//100
let hundrendString = "Hundred"
//0 ~ 19
let tenthStrings = ["Zero", "One", "Two", "Three", "Four", "Five", "Six", "Seven", "Eight", "Nine","Ten","Eleven", "Twelve", "Thirteen", "Fourteen", "Fifteen", "Sixteen", "Seventeen", "Eighteen", "Nineteen"]
func appendStrWithSpace(_ input: inout String, _ append: String){
if (!append.isEmpty){
input.append(" ")
input.append(append)
}
}
func subString(_ subInt: Int) -> String {
var retString = ""
//百位
var value = subInt / 100
if (value > 0) {
appendStrWithSpace(&retString, tenthStrings[Int(value)])
appendStrWithSpace(&retString, hundrendString)
}
//十位
value = subInt % 100
if (value > 0) {
if (value >= 20) {
let v = value / 10
appendStrWithSpace(&retString, tenStrings[Int(v)])
}
else { //20一下單獨處理
appendStrWithSpace(&retString, tenthStrings[Int(value)])
return retString
}
}
//個位
value = value % 10
if (value > 0) {
appendStrWithSpace(&retString, tenthStrings[Int(value)])
}
return retString
}
let sectionsStrings = ["", "Thousand", "Million", "Billion"]
var retString = ""
for i in stride(from: intArray.count-1, through: 0, by: -1) {
//Error: 每個section內(nèi)部的頭部本來就合并了空格存璃,所以這里不需要再增加空格
let sub = subString(intArray[i])
if (!sub.isEmpty) {
retString.append(sub)
appendStrWithSpace(&retString, sectionsStrings[i])
}
}
retString = retString.trimmingCharacters(in: NSCharacterSet.whitespaces)
return retString
}
convIntToEng(12345)
273. Integer to English Words
最后編輯于 :
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
- 文/潘曉璐 我一進店門袍冷,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人猫牡,你說我怎么就攤上這事胡诗。” “怎么了淌友?”我有些...
- 文/不壞的土叔 我叫張陵煌恢,是天一觀的道長。 經(jīng)常有香客問我震庭,道長瑰抵,這世上最難降的妖魔是什么? 我笑而不...
- 正文 為了忘掉前任归薛,我火速辦了婚禮谍憔,結(jié)果婚禮上匪蝙,老公的妹妹穿的比我還像新娘。我一直安慰自己习贫,他們只是感情好逛球,可當我...
- 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著苫昌,像睡著了一般颤绕。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上祟身,一...
- 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼秽澳!你這毒婦竟也來了闯睹?” 一聲冷哼從身側(cè)響起,我...
- 正文 年R本政府宣布垦沉,位于F島的核電站,受9級特大地震影響仍劈,放射性物質(zhì)發(fā)生泄漏厕倍。R本人自食惡果不足惜,卻給世界環(huán)境...
- 文/蒙蒙 一贩疙、第九天 我趴在偏房一處隱蔽的房頂上張望讹弯。 院中可真熱鬧况既,春花似錦、人聲如沸组民。這莊子的主人今日做“春日...
- 文/蒼蘭香墨 我抬頭看了看天上的太陽臭胜。三九已至莫其,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間耸三,已是汗流浹背乱陡。 一陣腳步聲響...
推薦閱讀更多精彩內(nèi)容
- 問題 Convert a non-negative integer to its english words re...
- Convert a non-negative integer to its english words repre...
- 最近發(fā)現(xiàn)一個很好的網(wǎng)站叫做LeetCodeOJ乏沸,注冊一個賬號之后就可以在上面刷題,進一步加深對語言的熟悉爪瓜。多造點輪...
- 題目 Convert a non-negative integer to its english words re...