如何用Pythony驗證萬物歸一(考拉咨猜想)
規(guī)則
我拿到一個數(shù)number:
奇數(shù)則number= 3 * number + 1; 偶數(shù)則number= number // 2; 猜想:對于每一個正整數(shù),如此循環(huán),最終都能夠得到1。
python驗證
#!/usr/bin/env python3 # coding=utf-8 __author__ = "RidingRoad" START_NUMBER = 1 END_NUMBER = 1000001 def collatz_seq(number): """ 獲取到的number是奇數(shù),則number= 3 * number + 1; 偶數(shù)則number= number // 2; 如果考拉咨猜想真的成立,可以number=1,那么程序?qū)V?否則,考拉咨猜想不成立 :return:1 """ while True: if number == 1: return number else: # number為偶數(shù) if not number % 2: number = number // 2 else: # number為奇數(shù) number = 3 * number + 1 if __name__ == "__main__": # 存放驗證考拉咨猜想函數(shù)的結(jié)果 result = [] for i in range(START_NUMBER, END_NUMBER): # 驗證START_NUMBER, END_NUMBER之間的數(shù) result.append(collatz_seq(i)) # 顯示結(jié)果 print(result)
下面是1到1000,000的數(shù)字進行考拉咨猜想驗證的結(jié)果
[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,......]
可以看到:萬里挑一啊, so easy
古人的猜想,如果還是基于傳統(tǒng)的計算工具,那是多么的無聊單調(diào),我們可以用Python來瞬間完成,感謝龜叔哦.
這里我們就不自己肉眼判斷了,我們用filter
def verify(num): """判斷結(jié)果里的不是1的數(shù)""" return 1 != num if __name__ == "__main__": # 存放驗證考拉咨猜想函數(shù)的結(jié)果 result = [] for i in range(START_NUMBER, END_NUMBER): # 驗證START_NUMBER, END_NUMBER之間的數(shù) result.append(collatz_seq(i)) # 使用filter對結(jié)果進行判斷是否存在非1的數(shù) print(list(filter(verify,result))) """ filter(function or None, iterable) --> filter object Return an iterator yielding those items of iterable for which function(item) is true. If function is None, return the items that are true. """
結(jié)果
[]
輸出了一個[]空列表,說明result列表里全部為一,考拉咨猜想是可能正確的.為什么說可能,是因為我只驗證了1到1000000的數(shù)字. 剩下的數(shù)字, 大家自己驗證一下(可能需要很長時間哦)!
以上就是如何用Pythony驗證萬物歸一(考拉咨猜想)的詳細內(nèi)容,更多關(guān)于Pythony驗證萬物歸一(考拉咨猜想)的資料請關(guān)注腳本之家其它相關(guān)文章!
- python 機器學習的標準化、歸一化、正則化、離散化和白化
- 如何基于python實現(xiàn)歸一化處理
- python數(shù)據(jù)歸一化及三種方法詳解
- python實現(xiàn)幾種歸一化方法(Normalization Method)
- 詳解python實現(xiàn)數(shù)據(jù)歸一化處理的方式:(0,1)標準化
- python numpy 按行歸一化的實例
- Python數(shù)據(jù)預處理之數(shù)據(jù)規(guī)范化(歸一化)示例
- python 實現(xiàn)對數(shù)據(jù)集的歸一化的方法(0-1之間)
- 對python3 一組數(shù)值的歸一化處理方法詳解
- 基于數(shù)據(jù)歸一化以及Python實現(xiàn)方式
相關(guān)文章
全面了解Python的getattr(),setattr(),delattr(),hasattr()
下面小編就為大家?guī)硪黄媪私釶ython的getattr(),setattr(),delattr(),hasattr()。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-06-06python+matplotlib實現(xiàn)鼠標移動三角形高亮及索引顯示
這篇文章主要介紹了Python+matplotlib實現(xiàn)鼠標移動三角形高亮及索引顯示,具有一定借鑒價值,需要的朋友可以參考下2018-01-01pyspark 讀取csv文件創(chuàng)建DataFrame的兩種方法
今天小編就為大家分享一篇pyspark 讀取csv文件創(chuàng)建DataFrame的兩種方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-06-06Python中集合的創(chuàng)建及常用函數(shù)的使用詳解
這篇文章主要為大家詳細介紹了Python中集合的創(chuàng)建、使用和遍歷,集合常見的操作函數(shù),集合與列表,元組,字典的嵌套,感興趣的小伙伴可以了解一下2022-06-06