主頁 > 知識庫 > 如何用Pythony驗(yàn)證萬物歸一(考拉咨猜想)

如何用Pythony驗(yàn)證萬物歸一(考拉咨猜想)

熱門標(biāo)簽:百度地圖標(biāo)注位置怎么修改 大連crm外呼系統(tǒng) 洪澤縣地圖標(biāo)注 地圖標(biāo)注視頻廣告 梅州外呼業(yè)務(wù)系統(tǒng) 老人電話機(jī)器人 無錫客服外呼系統(tǒng)一般多少錢 高德地圖標(biāo)注是免費(fèi)的嗎 北京電信外呼系統(tǒng)靠譜嗎

規(guī)則

我拿到一個數(shù)number:

奇數(shù)則number= 3 * number + 1; 偶數(shù)則number= number // 2; 猜想:對于每一個正整數(shù),如此循環(huán),最終都能夠得到1。

python驗(yàn)證

#!/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__":
    # 存放驗(yàn)證考拉咨猜想函數(shù)的結(jié)果
    result = []
    for i in range(START_NUMBER, END_NUMBER):
        # 驗(yàn)證START_NUMBER, END_NUMBER之間的數(shù)
        result.append(collatz_seq(i))
    # 顯示結(jié)果
    print(result)

下面是1到1000,000的數(shù)字進(jìn)行考拉咨猜想驗(yàn)證的結(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)的計(jì)算工具,那是多么的無聊單調(diào),我們可以用Python來瞬間完成,感謝龜叔哦.

這里我們就不自己肉眼判斷了,我們用filter

def verify(num):
    """判斷結(jié)果里的不是1的數(shù)"""
    return 1 != num

if __name__ == "__main__":
    # 存放驗(yàn)證考拉咨猜想函數(shù)的結(jié)果
    result = []
    for i in range(START_NUMBER, END_NUMBER):
        # 驗(yàn)證START_NUMBER, END_NUMBER之間的數(shù)
        result.append(collatz_seq(i))
    # 使用filter對結(jié)果進(jìn)行判斷是否存在非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列表里全部為一,考拉咨猜想是可能正確的.為什么說可能,是因?yàn)槲抑或?yàn)證了1到1000000的數(shù)字. 剩下的數(shù)字, 大家自己驗(yàn)證一下(可能需要很長時間哦)!

以上就是如何用Pythony驗(yàn)證萬物歸一(考拉咨猜想)的詳細(xì)內(nèi)容,更多關(guān)于Pythony驗(yàn)證萬物歸一(考拉咨猜想)的資料請關(guān)注腳本之家其它相關(guān)文章!

您可能感興趣的文章:
  • python 機(jī)器學(xué)習(xí)的標(biāo)準(zhǔn)化、歸一化、正則化、離散化和白化
  • 如何基于python實(shí)現(xiàn)歸一化處理
  • python數(shù)據(jù)歸一化及三種方法詳解
  • python實(shí)現(xiàn)幾種歸一化方法(Normalization Method)
  • 詳解python實(shí)現(xiàn)數(shù)據(jù)歸一化處理的方式:(0,1)標(biāo)準(zhǔn)化
  • python numpy 按行歸一化的實(shí)例
  • Python數(shù)據(jù)預(yù)處理之?dāng)?shù)據(jù)規(guī)范化(歸一化)示例
  • python 實(shí)現(xiàn)對數(shù)據(jù)集的歸一化的方法(0-1之間)
  • 對python3 一組數(shù)值的歸一化處理方法詳解
  • 基于數(shù)據(jù)歸一化以及Python實(shí)現(xiàn)方式

標(biāo)簽:泉州 清遠(yuǎn) 安慶 吉林 岳陽 長春 洛陽 怒江

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《如何用Pythony驗(yàn)證萬物歸一(考拉咨猜想)》,本文關(guān)鍵詞  如,何用,Pythony,驗(yàn)證,萬物,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《如何用Pythony驗(yàn)證萬物歸一(考拉咨猜想)》相關(guān)的同類信息!
  • 本頁收集關(guān)于如何用Pythony驗(yàn)證萬物歸一(考拉咨猜想)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章