您好,登錄后才能下訂單哦!
這篇文章運用簡單易懂的例子給大家介紹python怎么實現水仙花數,代碼非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。
水仙花數是指一個3位正整數,它的每個位上的數字的3次冪之和等于它本身。(例如:1^3 + 5^3+ 3^3 = 153)
下面用一句代碼實現找出所有的水仙花數:
>>> >>> a = list(map(lambda x: x[1], filter(lambda x: x[0], [(i*100+j*10+k == i**3+j**3+k**3, i**3+j**3+k**3) for i in range(1, 10) for j in range(0, 10) for k in range(0, 10)]))) >>> print(a) [153, 370, 371, 407] >>>
說明:
上面的代碼可以分解三句代碼:
a = [(i*100+j*10+k == i**3+j**3+k**3, i**3+j**3+k**3) for i in range(1, 10) for j in range(0, 10) for k in range(0, 10)] b = filter(lambda x: x[0], a) c = list(map(lambda x: x[1], b))
第一句表示用列表推到遍歷所有的三位數,每個數都打上標記,是水仙花數著標記True,不是則標記False,標記和數放到一個元祖:(flag, value),所有元組放在一個list結構里。
第二句表示篩選出標記為True的元組。
第三句表示把第一句篩選出來的元組的第二個值放到list結構里。
加上print語句,執行一遍上面三句代碼即可明白。
關于python怎么實現水仙花數就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。