python怎樣判斷字符串是否為整數(shù)_第1頁
python怎樣判斷字符串是否為整數(shù)_第2頁
python怎樣判斷字符串是否為整數(shù)_第3頁
python怎樣判斷字符串是否為整數(shù)_第4頁
全文預(yù)覽已結(jié)束

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

第python怎樣判斷字符串是否為整數(shù)方法一:遞歸法

對(duì)于整數(shù)而言,例如111,可以看成11*10+1,而11又可以看成1*10+1。而-111可以看成(-11)*10-1,-11可以看成(-1)*10-1.根據(jù)這個(gè)特點(diǎn)可以采用遞歸的方法求解,可以先根據(jù)字符串的第一個(gè)字符確定整數(shù)的正負(fù),接著對(duì)字符串從右向左遍歷.

classTest:

def__init__(self):

self.flag=None

defgetFlag(self):

returnself.flag

#判斷c是否是數(shù)字,如果是返回?cái)?shù)字,且設(shè)置flag=True,否則返回False

defisNumber(self,c):

returnc=0andc=9

#判斷str是否是數(shù)字

defstrtoint(self,strs,length):

iflength1:

ifnotself.isNumber(list(strs)[length-1]):

#不是數(shù)字

print(不是數(shù)字)

self.flag=False

return-1

iflist(strs)[0]==-:

returnself.strtoint(strs,length-1)*10-(ord(list[length-1])-ord(0))

else:

returnself.strtoint(strs,length-1)*10+ord(list(strs)[length-1])-ord(0)

else:

iflist(strs)[0]==-:

return0

else:

ifnotself.isNumber(list(strs)[0]):

print(不是數(shù)字)

self.flag=False

return-1

returnord(list(strs)[0])-ord(0)

defstrToint(self,s):

self.flag=True

ifs==Noneorlen(s)=0or(list(s)[0]==-andlen(s)==1):

print(不是數(shù)字)

self.flag=False

return-1

iflist(s)[0]==+:

returnself.strToint(s[1:len(s)],len(s)-1)

else:

returnself.strToint(s,len(s))

方法二:非遞歸法

首先通過一個(gè)字符的值確定整數(shù)的正負(fù)性,然后去掉符號(hào)位,把后面的字符串當(dāng)做正數(shù)來處理,處理完成后再根據(jù)正負(fù)性返回正確的結(jié)果。實(shí)現(xiàn)方法為從左向右遍歷字符串計(jì)算整數(shù)的值,以123為例,遍歷到2的時(shí)候結(jié)果為1*10+2=12,遍歷到3的時(shí)候結(jié)果為12*10+3=123。

classTest:

def__init__(self):

self.flag=None

defgetFlag(self):

returnself.flag

#判斷c是否是數(shù)字,如果是返回True,否則返回False

defisNumber(self,c):

returnc=0andc=9

defstrToint(self,strs):

ifstrs==None:

self.flag=False

print(不是數(shù)字)

return-1

self.flag=True

res=0

i=0

minus=False#是否是負(fù)數(shù)

iflist(strs)[i]==-:#結(jié)果是負(fù)數(shù)

minus=True

i+=1

iflist(strs)[i]==+:#結(jié)果是正數(shù)

i+=1

whileilen(strs):

ifself.isNumber(list(strs)[i]):

res=res*10+ord(list(strs)[i])-ord(0)

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論