利用Python判斷整數(shù)是否是回文數(shù)的3種方法總結(jié)
前言
所謂回文數(shù),就是說一個數(shù)字從左邊讀和從右邊讀的結(jié)果是一模一樣的,比如12321。本文通過三個方法詳細(xì)介紹了判斷的方法,下面來一起看看吧
方法一:逐位判斷
原理: 用一個while循環(huán),將一個數(shù)每次都取出首位和末位,判斷是否相等,只要有一次不相等退出即可。
回文數(shù)的判斷條件:加入一個變量位數(shù),如果這個數(shù)是奇數(shù),位數(shù)為1時,即最中間那一位數(shù),此時退出即可,同理,偶數(shù),位數(shù)為0時,退出。
問題:
- 如何判斷位數(shù)
- 如何逐位取值
優(yōu)點(diǎn): 思路簡單
解決:
判斷位數(shù)下面程序即可
y=x weishu=0 while x: weishu+=1 x=x//10
先將判斷的x賦值給y,當(dāng)x不為0時,表明現(xiàn)在x還有位數(shù),位數(shù)+1,x/10減少一位,但要記住,用地板除(//)直接得到int整數(shù),否則用/會出現(xiàn)浮點(diǎn)數(shù)
逐位取值:
a=y//(10**(weishu-1)) b=y%10 if a!=b: print("不是回文數(shù)。") break weishu-=2 y=y//10 y=y%(10**weishu)
取得首位只要地板除以相應(yīng)的位數(shù),把首位后面的數(shù)舍去,比如一個五位數(shù),地板除10000(10的4次方,所以是位數(shù)-1),就會得到首位,末尾比較簡單,只要對10取模得到余數(shù)就是各位,a是首位,b是末位。
判斷首尾相等后,先將位數(shù)-2,然后將首尾的數(shù)字都給刪掉,刪掉末位//10即可,刪掉首位:如果是五位數(shù),現(xiàn)在刪掉末位后是四位數(shù),地板與1000取模即可
然后是判斷如何判斷退出循環(huán)
如上文,判斷位數(shù)最后的值即可
最后判斷負(fù)數(shù)和個位數(shù)即可
實(shí)現(xiàn)代碼如下:
x=int(input("請輸入一個整數(shù):")) if x<0: print("不是回文數(shù)。") elif not x//10: print("是回文數(shù)。") else: y=x weishu=0 while x: weishu+=1 x=x//10 while True: a=y//(10**(weishu-1)) b=y%10 if a!=b: print("不是回文數(shù)。") break weishu-=2 if weishu==1: print("是回文數(shù)。") break if not weishu: print("是回文數(shù)。") break y=y//10 y=y%(10**weishu)
方法二:得到顛倒后的數(shù)判斷
原理: 每一個回文數(shù)從中間切開前后都是相等的,所以得到一個回文數(shù)后面的數(shù)與前面的數(shù)比較即可
那么問題來了,如果是奇位數(shù),怎么判斷?
解決: 只要最后得到的前面的數(shù)或者后面的數(shù)除去末位數(shù)與另一個相等即可,因?yàn)槠嫖粩?shù)中間的數(shù)不用管,其他的數(shù)相等就可以,所以刪去末位判斷是否相等
難點(diǎn): 如何得到后面的數(shù)?
每次將后面的數(shù)乘上10,然后加上前面數(shù)的末位,前面的數(shù)地板除10消除末位即可
如何判斷后面的數(shù)已經(jīng)取好了,即退出循環(huán)的判斷條件是:
就是當(dāng)后面的數(shù)已經(jīng)大于等于前面的數(shù)就可以退出循環(huán)了
優(yōu)點(diǎn): 代碼簡單
實(shí)現(xiàn)程序如下:
hou=0 while(x>hou): hou=hou*10+x%10 x//=10 if x==hou or x==(hou//10): print("是回文數(shù)。") else: print("不是回文數(shù)。")
最后判斷負(fù)數(shù)和末位是0但不是0的數(shù),他們一定不是回文數(shù),因?yàn)殚_頭不能是0
個位數(shù)此程序能夠判斷,后面的數(shù)就是此個位數(shù),地板除10之后和前面一樣都是10,即回文數(shù)
最終程序:
x=int(input("請輸入一個整數(shù):")) if x<0 or(x%10==0 and x!=0): print("不是回文數(shù)。") elif not x//10: print("不是回文數(shù)。") else: hou=0 while(x>hou): hou=hou*10+x%10 x//=10 if x==hou or x==(hou//10): print("是回文數(shù)。") else: print("不是回文數(shù)。")
方法三:字符串處理
原理: 字符串其實(shí)是序列,我們只要將字符串倒過來判斷是否和原字符串相等就可以了
反轉(zhuǎn)可以用x[::-1]
實(shí)現(xiàn)代碼如下
x=input("請輸入一個整數(shù):") if x==x[::-1]: print("是回文數(shù)。") else: print("不是回文數(shù)。")
要是你說還能不能更高級一點(diǎn),還可以用條件表達(dá)式這樣寫
x=input("請輸入一個整數(shù):") print("是回文數(shù)。") if x==x[::-1] else print("不是回文數(shù)。")
但是如果他給你一個09890也會報錯,具體解決可以先轉(zhuǎn)化為int,再轉(zhuǎn)化為str
最終成品:
x=int(input("請輸入一個正整數(shù):")) x=str(x) print("是回文數(shù)。") if x==x[::-1] else print("不是回文數(shù)。")
總結(jié)
到此這篇關(guān)于利用Python判斷整數(shù)是否是回文數(shù)的3種方法總結(jié)的文章就介紹到這了,更多相關(guān)Python判斷整數(shù)是回文數(shù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
如何在Python函數(shù)執(zhí)行前后增加額外的行為
有的時候會需要在函數(shù)前后添點(diǎn)額外的功能(比如過濾、計時等)時,以前總是首先想到裝飾器。最近學(xué)習(xí)了Python的上下文管理器,所以本文就給大家介紹了如何在Python函數(shù)執(zhí)行前后增加額外的行為,有需要的朋友們可以參考借鑒,下面來一起看看吧。2016-10-10Python?requests用法和django后臺處理詳解
這篇文章主要給大家介紹了關(guān)于Python中requests用法和django后臺處理的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2022-03-03基于PyQt5制作Excel數(shù)據(jù)分組匯總器
這篇文章主要介紹了基于PyQt5制作的一個小工具:Excel數(shù)據(jù)分組匯總器。文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起試一試2022-01-01tensorflow saver 保存和恢復(fù)指定 tensor的實(shí)例講解
今天小編就為大家分享一篇tensorflow saver 保存和恢復(fù)指定 tensor的實(shí)例講解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-07-07利用Python創(chuàng)建第一個Django框架程序
這篇文章主要介紹了利用Python創(chuàng)建第一個Django框架程序,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價值,感興趣的小伙伴可以參考一下2022-06-06Python實(shí)現(xiàn)解析與生成JSON數(shù)據(jù)
JSON文件是一種輕量級的數(shù)據(jù)交換格式,它采用了一種類似于JavaScript語法的結(jié)構(gòu),可以方便地在不同平臺和編程語言之間進(jìn)行數(shù)據(jù)交換,下面我們就來學(xué)習(xí)一下Python如何使用內(nèi)置的json模塊來讀取和寫入JSON文件吧2023-12-12Python?GDAL庫在Anaconda環(huán)境中的配置方法
這篇文章主要介紹了Python?GDAL庫在Anaconda環(huán)境中的配置,本文介紹在Anaconda環(huán)境下,安裝Python中柵格、矢量等地理數(shù)據(jù)處理庫GDAL的方法,需要的朋友可以參考下2023-04-04