這篇文章主要介紹“Python中不使用If-Elif 語句怎么判斷某個數(shù)字所屬的等級”,在日常操作中,相信很多人在Python中不使用If-Elif 語句怎么判斷某個數(shù)字所屬的等級問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”Python中不使用If-Elif 語句怎么判斷某個數(shù)字所屬的等級”的疑惑有所幫助!接下來,請跟著小編一起來學(xué)習(xí)吧!
建網(wǎng)站原本是網(wǎng)站策劃師、網(wǎng)絡(luò)程序員、網(wǎng)頁設(shè)計(jì)師等,應(yīng)用各種網(wǎng)絡(luò)程序開發(fā)技術(shù)和網(wǎng)頁設(shè)計(jì)技術(shù)配合操作的協(xié)同工作。成都創(chuàng)新互聯(lián)專業(yè)提供成都做網(wǎng)站、成都網(wǎng)站制作,網(wǎng)頁設(shè)計(jì),網(wǎng)站制作(企業(yè)站、成都響應(yīng)式網(wǎng)站建設(shè)公司、電商門戶網(wǎng)站)等服務(wù),從網(wǎng)站深度策劃、搜索引擎友好度優(yōu)化到用戶體驗(yàn)的提升,我們力求做到極致!
題目大意是:有從 A 到 F 的 5 個等級,現(xiàn)要判斷某個數(shù)值(從 0 到 1 之間)所屬的等級。舉例,如數(shù)值 >= 0.9,則屬于 A;若數(shù)值 >= 0.8,則屬于 B;以此類推。
若使用 if-elif 語句,可能寫成這樣:
if scr >= 0.9: print('A') elif scr >= 0.8: print('B') elif scr >= 0.7: print('C') elif scr >= 0.6: print('D') else: print('F')
此寫法出現(xiàn)了很多重復(fù)的模式,不夠簡潔優(yōu)雅。有什么更好的寫法,來實(shí)現(xiàn)這個目的呢?
該問題下的回答挺多的,實(shí)現(xiàn)思路五花八門。我挑幾個可讀性比較好:
方法一:使用bisect模塊(數(shù)字可調(diào))
方法二:使用 zip() 與 next()
方法三:使用字典(僅適用于 Python 3.6 以上的有序字典)
還有其它幾個回答,雖然都能實(shí)現(xiàn)數(shù)字分級的目的,但是其可讀性要差很多,因?yàn)樗鼈円葱枰阕饔?jì)算和推理,要么就是引入了額外的變量。
感興趣的話,你可在這個地址查看全部答案:https://stackoverflow.com/questions/61030617/how-can-i-simplify-repetitive-if-elif-statements
縱觀全部答案后,我認(rèn)為還是使用bisect的方法比較高效優(yōu)雅,不愧是它獲得了很高的贊同票。
這里簡單分析下它的實(shí)現(xiàn)過程。
bisect是 Python 內(nèi)置的標(biāo)準(zhǔn)庫,實(shí)現(xiàn)了二分查找算法。所謂二分查找,也被稱為“折半查找”(Binary Search),其基本思想是把有序排列的 n 個元素平均分成兩半,然后將待查找的 x 與中間元素比較,若 x 小于中間元素,則將左半段二分,再將 x 與其中間元素比對,以此類推。
這是一個簡單的圖示例子:
bisect庫中的 bisect() 方法,查找元素 x 在一個升序序列中的插入點(diǎn) i,使得插入點(diǎn)左側(cè)的元素都小于等于 x,插入點(diǎn)右側(cè)的元素都大于 x。
對照前面的例子:
from bisect import bisect def grade(score, breakpoints=[60, 70, 80, 90], grades='FDCBA'): i = bisect(breakpoints, score) return grades[i]
可以化簡成兩部分:
bisect([60, 70, 80, 90], score),返回插入點(diǎn)的值。假如 score 是 59,計(jì)算得出插入點(diǎn)在 60 的左側(cè),而 Python 列表的索引值是以 0 開始,所以返回插入點(diǎn)的值為 0;假如 score 是 60,計(jì)算得出插入點(diǎn)在 60 的右側(cè),即返回索引值為 1。
'FDCBA'[i],返回索引值為 i 的字符。假如 i 是 0,得到“F”;假如 i 是 3,得到“B”……
二分查找算法是效率較高的算法,時間復(fù)雜度為 O(logn)。該題目的查找范圍很小,所以時間效率差別不大。但是其寫法稱得上是 Pythonic,值得借鑒。
另外,再看看前面的方法三(使用字典),它的可讀性很強(qiáng),即順次將 scr 與字典中的值比較(從高往低,即 0.9~0.5),以此得出對應(yīng)的鍵值。(PS:它多分了一個“E”級,可去掉)
如果 Python 版本低于 3.6,則 grades.items() 會是無序的,將會破壞比較的順序。為了兼容性,可以修改成 sorted(grades.items()):
這種寫法沒有引入額外的庫,使用的 items() 與 sorted() 都是基礎(chǔ)知識(相比于方法二的 zip() 與 next()),簡單實(shí)用,也非常值得推薦。
不管怎么說,反復(fù)使用 if-elif 語句的判斷方式是挺笨拙的,必須改進(jìn)。
到此,關(guān)于“Python中不使用If-Elif 語句怎么判斷某個數(shù)字所屬的等級”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識,請繼續(xù)關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬?shí)用的文章!
當(dāng)前標(biāo)題:Python中不使用If-Elif語句怎么判斷某個數(shù)字所屬的等級
網(wǎng)址分享:http://newbst.com/article30/jheepo.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供小程序開發(fā)、品牌網(wǎng)站建設(shè)、品牌網(wǎng)站制作、ChatGPT、商城網(wǎng)站、關(guān)鍵詞優(yōu)化
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)