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