关于停机问题的一点思考

从最大公约数讲起

如果要计算90和21的最大公约数,根据欧几里德的定理,等同于求21和6的最大公约数,进一步等同于求6和3的最大公约数,经过几步转化,最终我们得到了结果:3。

这样一系列“有限”的步骤的集合,我们称之为算法。假设我们把求最大公约数算法的名字就叫做GCD,当我们说GCD作用于90和21可以停机的时候,转成大白话就是:GCD(90, 21)不会陷入死循环,并且返回值是3。事实上,GCD对于“任何合法”的输入总是能停机的。

那么可不可以进一步问:有没有这样一个算法,对于任意一个给定的程序和输入,可以判断出这个程序是否会停机[1]

停机问题的一种证明方式

假设我们有一个程序,就叫will-stop?,它可以针对任意的程序algorithm和输入input,返回是否可以停机,写成伪代码就是:

bool will-stop?(algorithm, input) {
  // return true or false
}

接着我们来设计一个叫evil的程序,它接受一个程序algorithm,在内部,它调用will-stop?并根据返回做一个相反的动作。写成伪代码也就是:

void evil(algorithm) {
  if (will-stop?(algorithm, algorithm)) {
    // 当返回true,就进行一个不能停机的死循环
    while(true)
  } else {
    // 当返回false,就立即执行一个停机动作
    return
  }
}

接下来我们尝试用will-stop?来判断一下evil(evil)这个函数调用是否会停机。也就是:will-stop?(evil, evil)输出的到底是什么?为了方便表述,我们同时也用evil1和evil2指代上面的evil,也就是说evil、evil1、evil2 这3者是等价的。

下面我们用will-stop?(evil1, evil2)代替之前的will-stop?(evil, evil)。

  • 假设evil1(evil2)能停机,也就是will-stop?(evil1, evil2)返回的是true,我们把evil2代入到evil1的函数体中,也就说evil1内部的will-stop?(evil2, evil2)返回的是false,也就是说它告诉我们evil2(evil2)不会停机。但是,别忘了evil1(evil2)和evil2(evil2)代表的其实都是evil(evil),所以will-stop?的结果自相矛盾了。

  • 那么,反过来呢?假设evil1(evil2)不能停机,则evil1内部的will-stop?(evil2, evil2)必然返回true,也就是说它告诉我们evil2(evil2)停机了。依然还是自相矛盾。

也就是说,无论怎么假设都无法让内部和外部的will-stop?达成一致。因此,我们说,不存在这样一个算法,对于任意一个给定的程序和输入,都可以判定出该程序是否会停机。也就是说,停机问题是不可判定的。

写在后面

证明的部分我参考了Daniel Friedman[2]以及刘未鹏[3]的实现。同时,做了一些表述上的优化,并补充了一些背景知识[4],使它看起来不像是一个冷冰冰的数学问题。

参考资料

[1] Halting problem
[2] 《The Little Schemer - 4th Edition》
[3] 康托尔、哥德尔、图灵——永恒的金色对角线(rev#2)
[4] 《计算进化史:改变数学的命运》

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,277评论 6 503
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,689评论 3 393
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 163,624评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,356评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,402评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,292评论 1 301
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,135评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,992评论 0 275
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,429评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,636评论 3 334
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,785评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,492评论 5 345
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,092评论 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,723评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,858评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,891评论 2 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,713评论 2 354

推荐阅读更多精彩内容