字符轉換 字符串轉換整數 (atoi) 字符轉數字(char轉int方法)

請你來實現一個?atoi?函數程梦,使其能將字符串轉換成整數岂贩。

首先拼缝,該函數會根據需要丟棄無用的開頭空格字符,直到尋找到第一個非空格的字符為止了嚎。

當我們尋找到的第一個非空字符為正或者負號時硝训,則將該符號與之后面盡可能多的連續(xù)數字組合起來,作為該整數的正負號新思;假如第一個非空字符是數字窖梁,則直接將其與之后連續(xù)的數字字符組合起來,形成整數夹囚。

該字符串除了有效的整數部分之后也可能會存在多余的字符纵刘,這些字符可以被忽略,它們對于函數不應該造成影響荸哟。

注意:假如該字符串中的第一個非空格字符不是一個有效整數字符假哎、字符串為空或字符串僅包含空白字符時,則你的函數不需要進行轉換舵抹。

在任何情況下劣砍,若函數不能進行有效的轉換時,請返回 0迅腔。

說明:

假設我們的環(huán)境只能存儲 32 位大小的有符號整數靠娱,那么其數值范圍為?[?231,? 231?? 1]像云。如果數值超過這個范圍,請返回 ?INT_MAX (231?? 1) 或?INT_MIN (?231)

來源:力扣(LeetCode)

鏈接:https://leetcode-cn.com/problems/string-to-integer-atoi

我的實現:

class Solution {

? ? public int myAtoi(String str) {

? ? ? int lenth=str.length();

? ? ? ? if(lenth==0) return 0;

? ? ? ? int tag=1;

? ? ? ? Stack<Integer> st = new Stack<Integer>();

? ? ? ? int i=0;


? ? ? ? if(Character.isDigit(str.charAt(0))){

? ? ? ? ? ? if(lenth==1) return str.charAt(0)-'0';

? ? ? ? ? ? if(str.charAt(i)!='0'){

? ? ? ? ? ? st.push(str.charAt(0)-'0');}

? ? ? ? ? ? i=1;

? ? ? ? ? ? while(i<lenth&&Character.isDigit(str.charAt(i))){

? ? ? ? ? ? if(!(st.isEmpty()&&str.charAt(i)=='0')){


? ? ? ? ? ? ? ? st.push(str.charAt(i)-'0');


? ? ? ? ? ? }

? ? ? ? ? ? i++;

? ? ? ? ? ? }


? ? ? ? }

? ? ? ? ? ? else if(str.charAt(0)=='-'||str.charAt(0)=='+'){

? ? ? ? ? ? ? ? if(lenth==1) return 0;

? ? ? ? ? ? ? ? if(str.charAt(0)=='-') tag=-1;


? ? ? ? ? ? ? ? i=1;

? ? ? ? ? ? ? ? while(i<lenth&&Character.isDigit(str.charAt(i))){

? ? ? ? ? ? ? ? if(!(st.isEmpty()&&str.charAt(i)=='0')){


? ? ? ? ? ? ? ? ? ? ? ? st.push(str.charAt(i)-'0');


? ? ? ? ? ? ? ? ? ? }

? ? ? ? ? ? ? ? i++;

? ? ? ? ? ? ? ? }


? ? ? ? ? ? }

? ? ? ? ? ? else if(str.charAt(0)==' '){


? ? ? ? ? ? ? ? if(lenth==1) return 0;


? ? ? ? ? ? ? ? i=1;

? ? ? ? ? ? ? ? while(i<lenth&&str.charAt(i)==' ') {i++;}

? ? ? ? ? ? ? ? if(i==lenth) return 0;

? ? ? ? ? ? ? ? if(str.charAt(i)=='-'){tag=-1;i++;}

? ? ? ? ? ? ? ? if(str.charAt(i)=='+'){i++;}


? ? ? ? ? ? ? ? while(i<lenth&&Character.isDigit(str.charAt(i))){

? ? ? ? ? ? ? ? if(!(st.isEmpty()&&str.charAt(i)=='0')){


? ? ? ? ? ? ? ? ? ? ? ? st.push(str.charAt(i)-'0');


? ? ? ? ? ? ? ? ? ? }

? ? ? ? ? ? ? ? i++;


? ? ? ? ? ? ? ? }






? ? ? ? ? ? }

? ? ? ? ? ? else{

? ? ? ? ? ? ? ? return 0;

? ? ? ? ? ? }


? ? ? ? ? ? long num=0;

? ? ? ? ? ? int a=0;

? ? ? ? ? ? int temp=0;

? ? ? ? ? ? int tt=0;

? ? ? ? ? ? while(! st.isEmpty()){


? ? ? ? ? ? ? ? a = (Integer) st.pop().intValue();

? ? ? ? ? ? ? ? num=num+a*(long)Math.pow(10,temp);

? ? ? ? ? ? ? ? tt++;

? ? ? ? ? ? ? ? if(tag==1){

? ? ? ? ? ? ? ? if (num>Integer.MAX_VALUE||tt>=11) return Integer.MAX_VALUE;}

? ? ? ? ? ? ? ? if(tag==-1){

? ? ? ? ? ? ? ? if (num*-1 < Integer.MIN_VALUE||tt>=11) return Integer.MIN_VALUE;}


? ? ? ? ? ? ? ? temp++;

? ? ? ? ? ? }

? ? ? ? ? ? return (int)num*tag;

? ? }

}

這道題走了n多坑闲礼,坑總結:?while(Character.isDigit(str.charAt(i)))->?while(i<lenth&&Character.isDigit(str.charAt(i)))

原因:沒有考慮到str.charAt(i)會越界的問題柬泽;

?? if (num>Integer.MAX_VALUE&&tt>=10)->?if (num>Integer.MAX_VALUE||tt>=11)

原因:在遇到20000000000000000的時候報錯嫁蛇,原因是當num有數的時候直接超出了long的可表示范圍;

?num=num+a*Math.pow(10,temp);->?num=num+a*(long)Math.pow(10,temp);

原因:Math.pow(10,temp)可能超過int存儲范圍第煮,數組會截取

沒有考慮-00000123456這種情況

知識點總結:

判斷str某個字符是不是數字抑党? Character.isDigit(str.charAt(i))

字符轉數字(char轉int方法):?str.charAt(i)-'0'


letcode精選方法:

python一行:

class Solution:

? ? def myAtoi(self, s: str) -> int:

? ? ? ? return max(min(int(*re.findall('^[\+\-]?\d+', s.lstrip())), 2**31 - 1), -2**31)


使用正則表達式:

^:匹配字符串開頭

[\+\-]:代表一個+字符或-字符

?:前面一個字符可有可無

\d:一個數字

+:前面一個字符的一個或多個

\D:一個非數字字符

*:前面一個字符的0個或多個

max(min(數字, 2**31 - 1), -2**31) 用來防止結果越界

作者:QQqun902025048

鏈接:https://leetcode-cn.com/problems/string-to-integer-atoi/solution/python-1xing-zheng-ze-biao-da-shi-by-knifezhu/

來源:力扣(LeetCode)

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
  • 序言:七十年代末底靠,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子暑中,更是在濱河造成了極大的恐慌,老刑警劉巖稻轨,帶你破解...
    沈念sama閱讀 217,826評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件政冻,死亡現場離奇詭異粱挡,居然都是意外死亡询筏,警方通過查閱死者的電腦和手機竖慧,發(fā)現死者居然都...
    沈念sama閱讀 92,968評論 3 395
  • 文/潘曉璐 我一進店門踱讨,熙熙樓的掌柜王于貴愁眉苦臉地迎上來痹筛,“玉大人,你說我怎么就攤上這事帚稠〈布眩” “怎么了滋早?”我有些...
    開封第一講書人閱讀 164,234評論 0 354
  • 文/不壞的土叔 我叫張陵砌们,是天一觀的道長杆麸。 經常有香客問我浪感,道長昔头,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,562評論 1 293
  • 正文 為了忘掉前任揭斧,我火速辦了婚禮,結果婚禮上赢笨,老公的妹妹穿的比我還像新娘未蝌。我一直安慰自己,他們只是感情好茧妒,可當我...
    茶點故事閱讀 67,611評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著纸型,像睡著了一般。 火紅的嫁衣襯著肌膚如雪狰腌。 梳的紋絲不亂的頭發(fā)上瑰枫,一...
    開封第一講書人閱讀 51,482評論 1 302
  • 那天丹莲,我揣著相機與錄音,去河邊找鬼。 笑死洲赵,一個胖子當著我的面吹牛鸳惯,可吹牛的內容都是我干的。 我是一名探鬼主播叠萍,決...
    沈念sama閱讀 40,271評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼芝发,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了俭令?” 一聲冷哼從身側響起后德,我...
    開封第一講書人閱讀 39,166評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎抄腔,沒想到半個月后瓢湃,有當地人在樹林里發(fā)現了一具尸體,經...
    沈念sama閱讀 45,608評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡赫蛇,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,814評論 3 336
  • 正文 我和宋清朗相戀三年绵患,在試婚紗的時候發(fā)現自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片悟耘。...
    茶點故事閱讀 39,926評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡落蝙,死狀恐怖,靈堂內的尸體忽然破棺而出暂幼,到底是詐尸還是另有隱情筏勒,我是刑警寧澤,帶...
    沈念sama閱讀 35,644評論 5 346
  • 正文 年R本政府宣布旺嬉,位于F島的核電站管行,受9級特大地震影響,放射性物質發(fā)生泄漏邪媳。R本人自食惡果不足惜捐顷,卻給世界環(huán)境...
    茶點故事閱讀 41,249評論 3 329
  • 文/蒙蒙 一荡陷、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧迅涮,春花似錦废赞、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,866評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至戏溺,卻和暖如春渣蜗,著一層夾襖步出監(jiān)牢的瞬間屠尊,已是汗流浹背旷祸。 一陣腳步聲響...
    開封第一講書人閱讀 32,991評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留讼昆,地道東北人托享。 一個月前我還...
    沈念sama閱讀 48,063評論 3 370
  • 正文 我出身青樓,卻偏偏與公主長得像浸赫,于是被迫代替她去往敵國和親闰围。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 44,871評論 2 354