一道面試題就能檢驗(yàn)出你的Python基礎(chǔ)如何,想知道題目是什么嗎?往下看
問:將 data 轉(zhuǎn)換成 new_data 這種形式,寫出轉(zhuǎn)換過程。
可以看出,轉(zhuǎn)換的過程是將 key 的下劃線進(jìn)行拆分,然后下劃線后邊的字符嵌套在前面字符的值中。
感興趣就打開 IDE,自己先試著解一下。
解題思路
你應(yīng)該很快想到,主要思路是將下劃線 split 后,然后依次使用字符生成內(nèi)層字典,當(dāng)達(dá)到最后一個(gè)字符時(shí)將數(shù)字作為值。
那么關(guān)鍵點(diǎn)在于,如何不斷地獲得內(nèi)層字典去修改呢?實(shí)際本題就是考察你是否理解 Python 字典是引用傳遞這個(gè)特性。
什么是引用傳遞?我們知道 Python 中字典和列表對(duì)象都是可變對(duì)象,同一個(gè)字典對(duì)象的變量不管如何傳遞,只要改變其中一個(gè)變量會(huì)同步修改其他變量。這是因?yàn)樽兞看鎯?chǔ)的只是可變對(duì)象的引用,無論調(diào)用哪個(gè)變量,返回的依然是同一個(gè)對(duì)象。比如:
如上,利用這個(gè)特性,將內(nèi)層字典賦值給一個(gè)中間變量,然后改變這個(gè)中間變量,即可同步修改最終的 new_data 變量。
根據(jù)這個(gè)思路,初步代碼如下:
這也是群友給出的第一版答案,這樣寫并沒有多大問題,但是代碼比較繁瑣,肯定還有優(yōu)化空間。
我們可以只使用一個(gè)中間變量即可,進(jìn)一步優(yōu)化:
上面這個(gè)代碼看似很簡潔了,但是仍然還有兩個(gè) if 判斷,如果不是使用了三元表達(dá)式的話,還會(huì)更多行。
所以可以進(jìn)一步優(yōu)化:
我們省略掉了 last 來判斷最后一個(gè)字符的索引,直接通過 keys[:-1] 避開最后一個(gè)字符,末尾再單獨(dú)生成數(shù)字鍵值對(duì)。
這里還使用字典的一個(gè)內(nèi)置方法 —— setdefault。
dict.setdefault(key, default=None) 方法和 get 方法類似,只是如果鍵不存在于字典中,不僅會(huì)返回 default 參數(shù)的值,還同時(shí)會(huì)用該值自動(dòng)生成一個(gè)鍵值對(duì)。
最終我們使用了 6 行代碼就解出該題,這也是接近最簡代碼。
如果使用字典引用的特性是合格分的話,那么當(dāng)你用出 setdefault 這個(gè)方法后,面試官已經(jīng)給你打了優(yōu)秀,因此一定要熟悉基礎(chǔ)數(shù)據(jù)對(duì)象的所有內(nèi)置方法。
最后歡迎大家添加我們的Python技術(shù)交流qq群:790693323 加群找管理免費(fèi)領(lǐng)取學(xué)習(xí)資料和項(xiàng)目代碼,等你來哦~~~