翻轉一個整數
今天又是給大家分享一個小的知識點 – 翻轉一個整數
相信我,知識點so so so easy……,並且很容易理解。
好了,閒話我們們就不多說了,直接開始今天的正題吧。
首先先來看下題目是什麼。
實現一個整數的翻轉
如:
- 初始值:123,翻轉後:321
- 初始值:-123,翻轉後:-321
首先不看答案,按照自己的想法來解答一遍。
1. 第一版
有多少同學看到題目的瞬間想起來的是下面這種解法、
- 首先將數字轉換為字串
- 然後判斷第一個字元
- 如果是符號,則擷取第一個字元後的內容
- 如果不是符號,則擷取全部
- 然後將得到的字串進行
str.split('')
操作 - 之後將得到的陣列進行
reverse
。 - 然後判斷是否要新增符號字首
- 最後得到正確答案。
?栗子:
function reverseInt (n) {
let str = `${n}`.split('')
let firstChar = str[0]
if (firstChar === '-') {
str = str.slice(1)
} else {
firstChar = ''
}
str = str.reverse().join('')
return (firstChar + str) * 1
}
接下來我們就來分析一下這個解法的優勢和劣勢
優勢:
- 容易理解,我們可以很清楚的知道每一步的執行原理 (貌似只有這一個優點)
劣勢:
- 資源浪費
- 需要先將數字轉換為字串
- 然後切分為陣列
- 然後翻轉陣列
- 之後再轉為字串
- 最後轉換為數字。
- 並且還需要關注當前整數是負數還是正數。
當然,這個解法肯定是對的,這個是毋庸置疑的,而且每個人都有每個人的理解。
但是~~
這裡還是要有但是,寫程式碼嘛,總得有點兒追求,追求用更省事省力的方式來解決問題。
下面我們再來看另一種解法
2. 第二版
接下來說的這種版本屬於數學運算的版本,但是也是比較好理解的一種。
好,不多說,我們直接來看下小栗子吧!
?栗子:
function reverseInt (n) {
let result = 0
while(n) {
let b = n % 10
n = ~~(n / 10)
result = result * 10 + b
}
return result
}
初看可能會有點兒不理解,莫慌,我們來解釋一下如何實現的。
解釋:
- 首先,我們定義了一個結果變數
result
用來儲存我們的執行結果。 - 迴圈變數
n
,知道n
為0
才結束。 - 接下來是重頭戲,也是這個演算法的核心實現。
- 每次迴圈都會將
n
的個位數值儲存下來。 - 然後讓
n
的長度減1
- 然後讓結果變數每次十倍之後新增我們儲存的數值。
- 每次迴圈都會將
- 迴圈結束後將
result
變數返回。 - 這裡我們用到了這樣一個運算子
~~
,這個是位運算。在這裡表示對運算結果取整。(詳細知識點可以檢視我之前的文章喲)
流程詳解:
接下來,我們通過原始值 123
來檢視下這個演算法的執行步驟吧。
第一次迴圈:
n = 123
result = 0
b = 123 % 10 = 3
n = 123 / 10 取整 = 12
result = 0 * 10 + 3 = 3
第二次迴圈:
n = 12
result = 3
b = 12 % 10 = 2
n = 12 / 10 取整 = 1
result = 3 * 10 + 2 = 32
第三次迴圈:
n = 1
result = 32
b = 1 % 10 = 1
n = 1 / 10 取整 = 0
result = 32 * 10 + 1 = 321
到這裡整個的演算法已經執行結束。通過驗證我們可以發現一個問題,此演算法對於負數來說同樣有效。
接下來我們來看下這個演算法的優勢
優勢:
- 不必關注是否是負數。
- 節省了大量轉換的成本。
- 節省了空間
- 利用了數學計算,避免了操作字串和陣列帶來的時間消耗。
OK,到這裡我們今天的分享內容就結束咯。
同樣,期待能給你帶來不一樣的理解和感悟。
Bye~
相關文章
- 翻轉整數
- 整數反轉:給出一個 32 位的有符號整數,你需要將這個整數中每位上的數字進行反轉。符號
- 輸入一個整數,返回這個整數的位數
- 給定一個 32 位有符號整數,將整數中的數字進行反轉。符號
- 反轉整數
- js小數轉整數JS
- 給出一個 32 位的有符號整數,你需要將這個整數中每位上的數字進行反轉。符號
- 整數反轉(ReverseInteger)
- 羅馬數字轉整數
- LeetCode每日一題:整數反轉(No.7)LeetCode每日一題
- 每日一道 LeetCode (2):整數反轉LeetCode
- 有一組整數資料,全部除以一個整數a,使得餘數是同n種數字,如何計算出這個整數a的全部可能。
- Visio對一個物件進行水平翻轉物件
- 每日一道 LeetCode (4):羅馬數字轉整數LeetCode
- python如何判斷一個數是否是整數Python
- LeetCode反轉整數(Python)LeetCodePython
- LeetCode(7)--.反轉整數LeetCode
- 7.整數反轉
- 字串轉換整數(atoi)字串
- 轉換成為整數
- 轉載:求任意2個整數互素的概率
- 每日一道演算法:整數反轉演算法
- [leetcode 25]. K 個一組翻轉連結串列LeetCode
- 2034 整數的個數
- 每日一道演算法:羅馬數字轉整數演算法
- Just for fun——分解一個正整數的質因數
- C# 輸入一個整數,求質因數C#
- Roman to Integer 羅馬數字轉整數
- LeetCode 13[羅馬數字轉整數]LeetCode
- 13. 羅馬數字轉整數
- leetcode:確實的第一個整數(java)LeetCodeJava
- 一個node連結串列翻轉的面試題面試題
- LeetCode 25. k個一組翻轉連結串列LeetCode
- Python:判斷一個正整數是否為迴文數Python
- 面試題:一個整數,它加上100後是一個完全...面試題
- 求兩個整數之和——一個寫註釋的新手
- LeetCode 力扣 羅馬數字轉整數LeetCode力扣
- 實現一個原子的正整數類:AtomicPositiveInteger