整數(shù)字符串轉(zhuǎn)成整數(shù)值

引言

我們剛寫(xiě)完32位整數(shù)轉(zhuǎn)化成英文表示和漢字表示,其中需要考慮Integer.MIN_VALUE的溢出情況,我們要做的這道題,更好的詮釋了對(duì)這種情況的處理.

分析

在開(kāi)始操作之前,我們要對(duì)這個(gè)字符串進(jìn)行判斷,看當(dāng)前的字符串是否是合法的,具體的判定過(guò)程如下:

public static boolean isValid(char[] chas) {
        if (chas[0] != '-' && (chas[0] < '0' || chas[0] > '9')) {
            return false;
        }
        if (chas[0] == '-' && (chas.length == 1 || chas[1] == '0')) {
            return false;
        }
        if (chas[0] == '0' && chas.length > 1) {
            return false;
        }
        for (int i = 1; i < chas.length; i++) {
            if (chas[i] < '0' || chas[i] > '9') {
                return false;
            }
        }
        return true;
    }

邏輯非常簡(jiǎn)單,先判斷第一位,然后在判斷后面的幾位,經(jīng)過(guò)了合法性的判斷.然后就開(kāi)始轉(zhuǎn)化了.我們?cè)谶@里統(tǒng)一先變成負(fù)數(shù),然后最后在判斷是正還是負(fù),先看代碼,然后在分析

public static int convert(String str) {
        if (str == null || str.equals("")) {
            return 0; // can not convert
        }
        char[] chas = str.toCharArray();
        if (!isValid(chas)) {
            return 0; // can not convert
        }
        boolean posi = chas[0] == '-' ? false : true;
        int minq = Integer.MIN_VALUE / 10;
        int minr = Integer.MIN_VALUE % 10;
        int res = 0;
        int cur = 0;
        for (int i = posi ? 0 : 1; i < chas.length; i++) {
            cur = '0' - chas[i];
            if ((res < minq) || (res == minq && cur < minr)) {
                return 0; // can not convert
            }
            res = res * 10 + cur;
        }
        if (posi && res == Integer.MIN_VALUE) {
            return 0; // can not convert
        }
        return posi ? -res : res;
    }

其中困擾我們的就是 int minq = Integer.MIN_VALUE / 10;
int minr = Integer.MIN_VALUE % 10;
這一段代碼,然后就是

 if ((res < minq) || (res == minq && cur < minr)) {
                return 0; // can not convert
            }

我們來(lái)解釋一下,這代碼的意思,我們首先知道,我們統(tǒng)一把值變成負(fù)值進(jìn)行判斷,因?yàn)镮nteger.MAX_VALUE和Integer.MIN_VALUE的關(guān)系,我們統(tǒng)一按照Integer.MIN_VALUE處理,那么如何判斷溢出的情況呢,我們截取書(shū)中的內(nèi)容:


圖片.png

這就是這個(gè)代碼最重要的地方.因?yàn)槿绻呀?jīng)溢出了,就沒(méi)法去判斷了,所以我們要在他溢出之前進(jìn)行判斷,而在沒(méi)有溢出的時(shí)候,就是兩種情況一定會(huì)溢出,就是上述截圖所說(shuō)的.
我們加深印象,將核心代碼在寫(xiě)一遍

for(int i=0;i<arr.length;i++)
{
       cur = '0'-arr[i];//全部是負(fù)數(shù)
       if(res<minq||(res==minq&&cur<minr))
       {   return 0;  }
      res=res*10+cur;
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子外里,更是在濱河造成了極大的恐慌拜效,老刑警劉巖螟够,帶你破解...
    沈念sama閱讀 219,270評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件檩奠,死亡現(xiàn)場(chǎng)離奇詭異佩番,居然都是意外死亡掐松,警方通過(guò)查閱死者的電腦和手機(jī)踱侣,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,489評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)大磺,“玉大人抡句,你說(shuō)我怎么就攤上這事「芾ⅲ” “怎么了待榔?”我有些...
    開(kāi)封第一講書(shū)人閱讀 165,630評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀(guān)的道長(zhǎng)流济。 經(jīng)常有香客問(wèn)我锐锣,道長(zhǎng),這世上最難降的妖魔是什么绳瘟? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,906評(píng)論 1 295
  • 正文 為了忘掉前任雕憔,我火速辦了婚禮,結(jié)果婚禮上糖声,老公的妹妹穿的比我還像新娘斤彼。我一直安慰自己分瘦,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,928評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布琉苇。 她就那樣靜靜地躺著嘲玫,像睡著了一般。 火紅的嫁衣襯著肌膚如雪并扇。 梳的紋絲不亂的頭發(fā)上去团,一...
    開(kāi)封第一講書(shū)人閱讀 51,718評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音穷蛹,去河邊找鬼土陪。 笑死,一個(gè)胖子當(dāng)著我的面吹牛俩莽,可吹牛的內(nèi)容都是我干的旺坠。 我是一名探鬼主播乔遮,決...
    沈念sama閱讀 40,442評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼扮超,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了蹋肮?” 一聲冷哼從身側(cè)響起出刷,我...
    開(kāi)封第一講書(shū)人閱讀 39,345評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎坯辩,沒(méi)想到半個(gè)月后馁龟,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,802評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡漆魔,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,984評(píng)論 3 337
  • 正文 我和宋清朗相戀三年坷檩,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片改抡。...
    茶點(diǎn)故事閱讀 40,117評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡矢炼,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出阿纤,到底是詐尸還是另有隱情句灌,我是刑警寧澤,帶...
    沈念sama閱讀 35,810評(píng)論 5 346
  • 正文 年R本政府宣布欠拾,位于F島的核電站胰锌,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏藐窄。R本人自食惡果不足惜资昧,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,462評(píng)論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望荆忍。 院中可真熱鬧格带,春花似錦诺凡、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,011評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至尔觉,卻和暖如春凉袱,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背侦铜。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,139評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工专甩, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人钉稍。 一個(gè)月前我還...
    沈念sama閱讀 48,377評(píng)論 3 373
  • 正文 我出身青樓涤躲,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親贡未。 傳聞我的和親對(duì)象是個(gè)殘疾皇子种樱,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,060評(píng)論 2 355

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

  • Lua 5.1 參考手冊(cè) by Roberto Ierusalimschy, Luiz Henrique de F...
    蘇黎九歌閱讀 13,812評(píng)論 0 38
  • Swift1> Swift和OC的區(qū)別1.1> Swift沒(méi)有地址/指針的概念1.2> 泛型1.3> 類(lèi)型嚴(yán)謹(jǐn) 對(duì)...
    cosWriter閱讀 11,103評(píng)論 1 32
  • 使用AVFoundation做拍照和視頻錄制開(kāi)發(fā)用到的相關(guān)類(lèi) AVCaptureSession:媒體(音、視頻)捕...
    131413閱讀 587評(píng)論 0 1
  • 一俊卤、列出IO操作的標(biāo)識(shí)符及描述 二嫩挤、讀TXT文件 要以讀文件的模式打開(kāi)一個(gè)文件對(duì)象,使用Python內(nèi)置的open...
    小喜_ww閱讀 1,828評(píng)論 0 2
  • 上一章[http://www.reibang.com/p/d465d5026db5] 目錄[https://ww...
    胥楓閱讀 467評(píng)論 6 7