按键盘上方向键 ← 或 → 可快速上下翻页,按键盘上的 Enter 键可回到本书目录页,按键盘上方向键 ↑ 可回到本页顶部!
————未阅读完?加入书签已便下次继续阅读!
110→01STOP,111→111R,1000→1011L,1001→1001R,1010→101L,1011→1011L。
在EUC的情形、为了得到有关的概念,人们可用一些明显的数对譬如6和8来试验。正如以前一样,阅读机处于态0,并且初始时处在左边,而现在磁带一开始的记号是这样子的:
…0000000000011111101111111100000…在许多步之后,图灵机停止,我们得到了具有如下记号的磁带:
…000011000000000000…
而阅读机处于这些非零位数的右边。这样,所需的最大公约数正是所需要的(正确的)2。要完全解释为何EUC(或者UN×2)在实际上完成所预想的,牵涉到许多微妙之处,而且解释本身比机器更复杂,这是电脑程序的通常特征! (为了完全理解一个算法步骤为何能做到所预想的,牵涉到洞察。“洞察”本身是算法的吗?这是一个对我们以后颇为重要的问题。)我不想在这里为EUC或UN×2提供解释。真正做过检验的读者会发现,为了在所需的方案中把事情表达得更精密一些,我自作主张地对欧几里德算法作了一些不重要的变通。EUC的描述仍然有些复杂,对于11种不同的内态包含有22条基本指令,大部分复杂性是纯粹组织形式的。例如,可以看到在22条指令中,只有三条真正涉及到在磁带上改变记号!(甚至对于UN×2用了12条指令,其中只有一半涉及到改变记号。)数据的二进位码用一进位系统表示大数极端无效率。正如早先描述的,我们将相应地用二进位计数系统。然而,不能直接地把磁带当作二进位数来读。如果这样做的话,就没有办法告知一个数的二进位表示何时结束,以及无限个0的序列是否代表右端开始的空白。我们需要某种终结一个数的二进位描述的记号。此外,我们还经常要输进几个数,正如欧几里德算法需要一对数2那样。问题在于,我们不能把数之间的间隔和作为单独的一个数的二进位表示中的一部分的0或一串0区分开来。此外,我们或许在输入磁带中包括所有种类复杂的指令和数。为了克服这些困难,让我们采用一种我称之为收缩的步骤。按照该步骤,任何一串0或一串1(共有有限个)不是简单地被当作二进位数来读,而是用一串0,1,2,3等来取代。其作法是,第二个序列的每一数字就是在第一个序列中的连续的0之间的1的个数。例如序列01000101101010110100011101010111100110就可被取代成:我们现在可以把数2,3,4,…当作某种记号或指令来读。让我们把2简单地当作表示两个数之间间隔的“逗号”,而根据我们的愿望,3, 4,5,…可以代表各种有兴趣的指令或记号,诸如“负号”、“加”、“乘”“到具有下面号码的位置”,“递归进行前面的运算如下面数目那么多次”等等。我们现在有了由更高的数分开的各种0和1的串。后者代表写成二进位的通常的数。这样上面可读成(“逗号”为2):(二进位数1001)逗号(二进位数11)逗号……。
使用标准的阿拉伯记号“9”,“3”,“4”,“0”来写相应的二进位1001,11,100,0,我们就得到整个序列:9,3,4(指令3)3(指令4)0,特别是,这一步骤给了我们一种简单地利用在结尾处逗号终结描述一个数的手段(并因此把它和在右边的无限长的空白带区分开来)。此外,它还使我们能对以二进位记号写成0和丨的单独序列的自然数的任何有限序列编码。让我们看看在一特定情形下这是怎么进行的。例如,考虑序列5,13,0,1,1,4在二进位记号中这是101,1101,0,1,1,100,它可用扩展(也就是和上面收缩相反)的步骤在磁带上编码成…000010010110101001011001101011010110100011000…为了直截了当地得到这个码,我们可在原先的二进位数序列上作如下代换:0→01→10,→110然后在两端加上无限个0。如果我们把它列出,就能更清楚地看出,如何把这个应用到上面的磁带上:000010010110101001011001101011010110100011000我将把这种数(的集合)的记号称为扩展二进位记号。(这样,例如13的扩展二进位形式为1010010)关于这种编码还有最后一点必须提及。这只不过是个技巧,但是为了完备起见是需要的3。在自然数的二进位(或十进位)表示中处于表式最左端的0是不“算”的,它通常可被略去,这里有些多余。例如00110010和110010是两个相同的二进位数(而0050和50为相同的十进位数)。这一多余可适合于数0本身,它也可写成000或00。一个空白的空间的确也应该逻辑地表示0!在通常的记号下这会导致巨大的混淆,但是它和上面刚描述的记号可相安无事。这样,在两个逗号之间的0可只写成两个连在一起的逗号(,,),它在磁带上被编码成两对由单独的0隔开的11:
…001101100…
这样,上面的六个数的集合也可用二进位记号写成101,1101,,1,1,100,而且在磁带上可以扩展的二进位方式编码成…00001001011010100101101101011010110100011000… (有一个0已从我们以前的序列中略去)。
现在我们可以考虑让一台图灵机,譬如讲欧几里德算法,把它应用到以扩展二进位记号写出的一对数上。例如,这一对数是我们早先考虑的6,8,不用以前用的…0000000000011111101111111100000…
而考虑6和8的二进位表示,也就是分别为110和1000。这一对为6,8,在二进位记号也就是110,1000扩展后在磁带上编码成…00000101001101000011000000…
对于这一对特殊的数,并没有比一进位形式更紧凑。然而,譬如说我们取(十进位数)1583169和8610。在二进位记号中它们是110000010100001000001,10000110100010,这样,我们在磁带上把这一对编码成…001010000001001000001000000101101000001010010000100110…只要用一行就可将其全部写出, 而如果用一进位记号的话, 表示 “1583169,8610”的磁带用这一整本书都写不下。当数用扩展二进位记号表示时,一台执行欧几里德算法的图灵机,如果需要的话,可以简单地把适当的一对在一进位和扩展二进位之间互相翻译的子程序算法接到EUC上去而得到。然而,由于一进位计数系统的无效率仍在“内部”存在,并且在仪器的迟缓以及需要大量的外部“粗纸” (它是磁带的右手部分)方面表现出来,实际上这是极其无效率的。可以给出全部用扩展二进位运算的、更有效率的、欧几里德算法的图灵机,但是它在这里对我们并无特别启发之处。
相反地,为了阐明如何使一台图灵机能对扩展二进位数运算,让我们尝试某种比欧几里德算法简单得多的东西,即是对一个自然数加一的过程。这可由(我称之为XN+1的)图灵机来执行:
00→00R,01→11R,10→00R,11→101R,100→110L,101→101R,110→01STOP,111→1000L,1000→1011L,1001→1001L,1010→1100R,1011→101R,1101→1111R,1110→111R,1111→1110R,某些勤奋的读者可把它应用到,譬如讲数167上去,以再次验证这一台图灵机在实际上做到了所预想的。这一个数的二进位表示可由下面的磁带给出:
…0000100100010101011000…
为了把一加到这个二进位数上,我们简单地找到最后的那个0,并把它改成1,然而用0来取代所有跟在后面的1。例如167+1=168在二进位记号下写成10100111+1=10101000。这样,我们的“加一”图灵机应把前面的磁带用…0000100100100001100000…来取代,它的确做到了这一点。
我们注意到,甚至这种简单加一的非常基本的运算在用这种记号时都会显得有些复杂,它使用了十五条指令和八种不同的内态!由于在一进位系统中“加一”只是把1的串再延长一个而已,事情当然是简单得多。所以我们的机器UN+1更为基本,这一点也不奇怪。然而,对于非常大的数,由于所需的磁带非同寻常地长,UN+1就会极慢。而用更紧凑的扩展二进位记号运算的更复杂的机器XN+1就会更好。作为旁白,我愿意指出对于扩展二进位比一进位图灵机显得更简单的一个运算,这就是乘二。在这里由00→00R,01→10R,10→01R,11→100R,100→111R,110→01STOP,给出的图灵机XN×2能在扩展的二进位上实现这个运算,而前面描述的相应于一进位的机器UN×2就要复杂得多!
我们从这里得到了,关于图灵机在非常基础水平上可做到的一些事情的概念。正如预料得到的,当进行某些复杂的运算时,它们会变得极为复杂。这种仪器的终极能力是什么呢?让我们在下面讨论这一个问题。撤屈――图灵主题人们一旦对建造简单的图灵机稍有一些熟悉,下面这些事实就很容易使他们感到满意。特殊的图灵机的确能执行各种基本的算术运算,诸如把两个数加到一起,或把它们相乘,或求一个数的到另一个数的方次。显明提供其结果