7. 反轉(zhuǎn)整數(shù)

20180919-摘抄自7. 反轉(zhuǎn)整數(shù)

給定一個 32 位有符號整數(shù),將整數(shù)中的數(shù)字進行反轉(zhuǎn)漓踢。

示例 1:

輸入: 123
輸出: 321

示例 2:

輸入: -123
輸出: -321

示例 3:

輸入: 120
輸出: 21

注意:

假設(shè)我們的環(huán)境只能存儲 32 位有符號整數(shù)挽鞠,其數(shù)值范圍是 [?231, 231 ? 1]疚颊。根據(jù)這個假設(shè),如果反轉(zhuǎn)后的整數(shù)溢出信认,則返回 0材义。

解決方案

方法:彈出和推入數(shù)字 & 溢出前進行檢查

思路

我們可以一次構(gòu)建反轉(zhuǎn)整數(shù)的一位數(shù)字。在這樣做的時候嫁赏,我們可以預先檢查向原整數(shù)附加另一位數(shù)字是否會導致溢出其掂。

算法

反轉(zhuǎn)整數(shù)的方法可以與反轉(zhuǎn)字符串進行類比。

我們想重復“彈出” x 的最后一位數(shù)字潦蝇,并將它“推入”到 rev 的后面款熬。最后,rev 將與 x 相反护蝶。

要在沒有輔助堆棧 / 數(shù)組的幫助下 “彈出” 和 “推入” 數(shù)字华烟,我們可以使用數(shù)學方法。

//pop operation:
pop = x % 10;
x /= 10;

//push operation:
temp = rev * 10 + pop;
rev = temp;

但是持灰,這種方法很危險盔夜,因為當 temp = rev * 10 + pop 時會導致溢出。

幸運的是堤魁,事先檢查這個語句是否會導致溢出很容易喂链。

為了便于解釋,我們假設(shè) rev 是正數(shù)妥泉。

如果 temp = rev * 10 + pop 導致溢出椭微,那么一定有 rev ≥ INTMAX / 10
如果 rev > INTMAX / 10盲链,那么 temp = rev * 10 + pop 一定會溢出蝇率。
如果 rev == INTMAX / 10迟杂,那么只要 pop > 7,temp = rev * 10 + pop 就會溢出本慕。
rev 為負時可以應用類似的邏輯排拷。

class Solution {
    public int reverse(int x) {
        int rev = 0;
        while (x != 0) {
            int pop = x % 10;
            x /= 10;
            if (rev > Integer.MAX_VALUE/10 || (rev == Integer.MAX_VALUE / 10 && pop > 7)) return 0;
            if (rev < Integer.MIN_VALUE/10 || (rev == Integer.MIN_VALUE / 10 && pop < -8)) return 0;
            rev = rev * 10 + pop;
        }
        return rev;
    }
}

復雜度分析

  • 時間復雜度:O(log(x)),x 中大約有 log 10 (x) 位數(shù)字锅尘。
  • 空間復雜度:O(1)监氢。
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市藤违,隨后出現(xiàn)的幾起案子浪腐,更是在濱河造成了極大的恐慌,老刑警劉巖顿乒,帶你破解...
    沈念sama閱讀 212,454評論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件议街,死亡現(xiàn)場離奇詭異,居然都是意外死亡淆游,警方通過查閱死者的電腦和手機傍睹,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,553評論 3 385
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來犹菱,“玉大人,你說我怎么就攤上這事吮炕±巴眩” “怎么了?”我有些...
    開封第一講書人閱讀 157,921評論 0 348
  • 文/不壞的土叔 我叫張陵龙亲,是天一觀的道長陕凹。 經(jīng)常有香客問我,道長鳄炉,這世上最難降的妖魔是什么杜耙? 我笑而不...
    開封第一講書人閱讀 56,648評論 1 284
  • 正文 為了忘掉前任,我火速辦了婚禮拂盯,結(jié)果婚禮上佑女,老公的妹妹穿的比我還像新娘。我一直安慰自己谈竿,他們只是感情好团驱,可當我...
    茶點故事閱讀 65,770評論 6 386
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著空凸,像睡著了一般嚎花。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上呀洲,一...
    開封第一講書人閱讀 49,950評論 1 291
  • 那天紊选,我揣著相機與錄音啼止,去河邊找鬼。 笑死兵罢,一個胖子當著我的面吹牛族壳,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播趣些,決...
    沈念sama閱讀 39,090評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼仿荆,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了坏平?” 一聲冷哼從身側(cè)響起拢操,我...
    開封第一講書人閱讀 37,817評論 0 268
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎舶替,沒想到半個月后令境,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,275評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡顾瞪,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,592評論 2 327
  • 正文 我和宋清朗相戀三年舔庶,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片陈醒。...
    茶點故事閱讀 38,724評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡惕橙,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出钉跷,到底是詐尸還是另有隱情弥鹦,我是刑警寧澤,帶...
    沈念sama閱讀 34,409評論 4 333
  • 正文 年R本政府宣布爷辙,位于F島的核電站彬坏,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏膝晾。R本人自食惡果不足惜栓始,卻給世界環(huán)境...
    茶點故事閱讀 40,052評論 3 316
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望血当。 院中可真熱鬧幻赚,春花似錦、人聲如沸歹颓。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,815評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽巍扛。三九已至领跛,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間撤奸,已是汗流浹背吠昭。 一陣腳步聲響...
    開封第一講書人閱讀 32,043評論 1 266
  • 我被黑心中介騙來泰國打工喊括, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人矢棚。 一個月前我還...
    沈念sama閱讀 46,503評論 2 361
  • 正文 我出身青樓郑什,卻偏偏與公主長得像,于是被迫代替她去往敵國和親蒲肋。 傳聞我的和親對象是個殘疾皇子蘑拯,可洞房花燭夜當晚...
    茶點故事閱讀 43,627評論 2 350

推薦閱讀更多精彩內(nèi)容