计算复杂性理论(一)
计算机深刻地改变了当今世界.如今,在面对一个问题时,我们可能会认为,只需要有足够的计算能力,就可以解决这个问题了.但事实并非如此.在本节就能看到,即使“简单”如判定性问题,亦有无穷多个问题不能使用计算机(图灵机)来进行判定.
因此,在处理问题时,我们首先会判断它是否可以识别、计算(可识别性与可判定性),在可以计算的基础上,会关心计算它至少要花费多少时间与空间(时间复杂性类与空间复杂性类),是否有别的模型可以更进一步进行计算(非确定性图灵机、概率图灵机、交互图灵机等产生的复杂性类),以及,理论上是否存在一个可达的更快的方法(复杂性类的包含与等价关系,例如,$\mathbf{P} \overset{\text{?} }{=} \mathbf{NP}$).
本节是计算复杂性理论 (Computational Complexity Theory)(亦称计算理论 (Theory of Computation))的第一部分.在本节,我们将讲述什么是图灵机、语言,以及判定类的问题可以如何分类.
基础符号规定
- 空字符串记为 $\epsilon$
- 字符串 $\omega$ 的长度表示为 $\vert\omega\vert$
- 若 $S$ 为符号集合,由 $S$ 中的符号串联构成的长度为 $n$ 的字符串的集合表示为 $S^n$,长度任意的字符串集合表示为 $S^\ast$(包含空字符串)
例:若 $S = \lbrace 0, 1\rbrace$,则 $S^2 = \lbrace 00, 01, 10, 11\rbrace$,$S^\ast = \lbrace \epsilon, 0, 1, 00, 01, 10, 11, 000, 001, \dots\rbrace$
一、图灵机与语言
1.1 图灵机
定义 1.1 本文将采用三纸带图灵机 (turing machine) $\text{M}$,定义为拥有
- 三条两端均无限长的纸带 (tape)
- 输入带(只读)input tape (read-only)
- 工作带(读写)work tape (read/write)
- 输出带(只写)output tape (write-only)
- 每个带子上有一个指针,初始位置固定
- 有限的符号 (symbol) 集 $\Gamma$
- $\Gamma$ 包含空白符 $\square$ 和有限个有效符号 $s_1, s_2, \dots, s_m$
- 有效符号的集合表示为 $\Sigma$,即 $\Sigma = \left\lbrace s_1, s_2, \dots, s_m\right\rbrace$,$\Sigma$ 需要至少包含两个符号
- 初始时,输入带上从初始位置向右写有输入 $\omega \in \Sigma^\ast$,输入带其他位置以及其他带子上都是空白符.输入为 $\omega$ 时可简记作 $\text{M}(\omega)$
- 有限的状态 (state) 集 $Q$
- $Q = \left\lbrace q_{\text{start} }, q_{\text{halt} }, q_{1}, q_{2}, \dots, q_{n}\right\rbrace$
- 其中,$q_{\text{start} }, q_{\text{halt} }$ 分别表示开始、停止状态,其他状态均为中间状态
- 初始时为开始状态 $q_{\text{start} }$
- 迁移函数 (transition function) $\delta$
\(\delta: \left(Q\setminus\left\lbrace q_{\text{halt} }\right\rbrace \right)\times\Gamma^2\to{Q}\times\Gamma^2\times\left\lbrace \text{L},\text{R},\text{S}\right\rbrace ^3 \\ \delta\left(q_{now}, s_a, s_b\right) = \left(q_{next}, s_b', s_c', D_a, D_b, D_c\right)\)- 左侧 $s_a, s_b$ 为前两个带子当前指针读到的值,右侧 $s_b’, s_c’$ 为后两个带子上写入的值
- $\text{L},\text{R},\text{S}$ 表示在进行完这次读写后,三条带子的指针分别左移、右移、不动
- 当当前状态在 $q_{now} \left(q_{now} \neq q_{\text{halt} } \right)$ 且前两个读入值为 $s_a, s_b$ 时,即会进行一次 $\delta$ 操作.将状态改为 $q_{next}$,并将后两个带子上的值改为 $s_b’, s_c’$,修改后,三条带子的指针分别进行 $D_a, D_b, D_c$ 方向的移动
- 如果进入 $q_{\text{halt} }$ 状态,则运行终止,即停机 (halt)
- 如果图灵机在输入 $\omega$ 停机,记作 $\text{M}(\omega)\downarrow$;否则记作 $\text{M}(\omega)\uparrow$
- 如果图灵机在停机时,输出带上写有内容 $\sigma$,则称图灵机输出 $\sigma$,记作 $\text{M}(\omega) = \sigma$
- 事先规定两个符号 $\left\lbrace s_{acc}, s_{rej} \right\rbrace \subseteq \Sigma$,分别表示接受 (accept) 和拒绝 (reject) 输入,一般用 $\left\lbrace 1, 0 \right\rbrace$ 指代.对于 $\text{M}(\omega) = \sigma$ 的输出,如果 $\sigma = 1$ 则表示接受输入 $\omega$;如果 $\sigma = 0$ 或 $\sigma$ 为其他值,均视为拒绝输入 $\omega$.接受和拒绝输入的定义,在判定性问题中非常重要,而在非判定性问题中,往往直接处理输出即可
- 另外,
- 迁移函数对于某些 $\left(q_z, s_x, s_y\right)$ 可能没有定义.如果在运行中遇到没有定义的情况,机器将立刻停机
- 注意,图灵机可能不会停机
有效符号集需要至少包含两个符号,此外并无其他要求.因此,我们可以编码将两个不同的有效符号集 $S_1, S_2$ 在常数 $c = \log_{\left\vert S_1\right\vert}(\left\vert S_2\right\vert)$ 的长度变化下由一个符号集映射到另一符号集,因而,不同的符号集在绝大多数情况下不影响结果.在本文的讨论中,都是假定已经规定好一个任意的符号集.
同样,我们可以让图灵机接收多个参数 $\omega_1, \omega_2, \dots, \omega_n$,多个参数之中可以用一个新字符隔开再重新编码为旧字符,或者让字符集一直拥有一个仅作为分割用的字符.此时,可简记作 $\text{M}\left(\omega_1, \omega_2, \dots, \omega_n\right)$.输出同理.
另外,由于自然数和字符串均可数,他们之间可以相互一一对应,所以有时会直接用自然数代替字符串,表示输入和输出.结合上文的结论,于是,
推论 1.2 图灵机可以表示为输入若干个字符串或自然数,并输出若干个字符串或自然数,此时记作 $\text{M}\left(\omega_1, \omega_2, \dots, \omega_n\right) = \left(o_1, o_2, \dots, o_m\right)$,括号内的每一项为自然数或字符串.
为了方便表述,我们给出记号
定义 1.3 所有图灵机构成的集合记为 $\mathbb{TM}$.
注1:更少的纸带的定义亦可,但是防止后续对严格处理 $\mathbf{L}$ 的复杂性产生影响,本文规定为三条.
注2:亦有使用 $q_{\text{accept} }, q_{\text{reject} }$ 的图灵机定义,但输出仍然是停机时的输出,因而这种定义在处理等价类时需要分判定性和非判定性问题讨论.
注3:其他定义可能与之略有出入,但不影响使用.
1.2 图灵机编号
由于二进制编码 link 的存在,图灵机的迁移函数的所有输入输出情况可以写为一个列表,并编码为二进制,从而表示一个具体的图灵机.
接着,我们将图灵机的编码从小到大排序,并依次映射到自然数上.由于图灵机集合 $\mathbb{TM}$ 中的编码有无穷多个,因此 $\mathbb{TM}$ 的势至少是 $\aleph_0$(最小的无穷势);又由于这些编码是 $\lbrace 0, 1\rbrace ^\ast$ 的子集,因此 $\mathbb{TM}$ 的势最大是 $\left\vert\lbrace 0, 1\rbrace ^\ast\right\vert=\aleph_0$.因此,它的势就是 $\aleph_0$,即 $\left\vert\mathbb{TM}\right\vert = \aleph_0$.因而,$\mathbb{TM}$ 和 $\mathbb{N}$ 等势,所以每个自然数 $n$ 都有一个对应的图灵机,每个图灵机 $\text{M}$ 也有一个对应的自然数,即
推论 1.4 自然数和图灵机一一对应.
定义 1.5 本文用 $\text{M}_n$ 表示自然数 $n$ 对应的图灵机,$\text{M}_n\in\mathbb{TM}$;用 $\langle{\text{M} }\rangle$ 表示图灵机 $\text{M}$ 对应的自然数,$\langle{\text{M} }\rangle\in\mathbb{N}$.
1.3 语言
定义 1.6 定义语言 (language) $L$ 如下,对于一个有限符号集 $\Sigma\;(\vert\Sigma\vert\geqslant2)$ 所构成的字符串集合 $\Sigma^\ast$,语言 $L$ 是 $\Sigma^\ast$ 的一个子集,即 $L \subseteq \Sigma^\ast$.
语言 $L$ 常常用文字描述.例如,在符号集 $\Sigma = \left\lbrace a, b\right\rbrace$ 时,“回文字符串”可以指代一种语言 $L_{pal}$,$L_{pal} = \left\lbrace \epsilon, a, b, aa, bb, aaa, aba, bab, bbb, \dots\right\rbrace$.$abbba$ 属于这个语言,而 $aaab$ 不属于这个语言.
语言可以为空,即 $L = \emptyset$,也可以只包含少量元素,例如 $L = \lbrace a, ba\rbrace, L = \lbrace\epsilon\rbrace$,当然也可以包含全部元素,即 $L = \Sigma^\ast$.
同样,语言的讨论也在一个特定的符号集中,本文同样假定已经规定好一个任意的符号集.如果同时在讨论图灵机,那么图灵机的有效符号集和这里的符号集是相同的.
定义 1.7 所有语言 $L$ 构成的集合记为 $\mathbb{L}$.
根据语言的定义,可知
推论 1.8 $\mathbb{L}$ 是 $\Sigma^\ast$ 的幂集,即 $\mathbb{L} = 2^{\Sigma^\ast}$,它的势 $\left\vert\mathbb{L}\right\vert = 2^{\aleph_0} \left(= \mathfrak{c}\right)$proof.
为了增加更多可以描述的性质,我们给出补集的表示.
定义 1.9 语言 $L$ 的补集对应的语言记为 $\overline{L}$,即 $\overline{L} = \Sigma^\ast \setminus L$,称为 $L$ 的补 (complement).
另外,很多语言虽然不同,但是往往有类似的性质.同样为了方便,我们把不同语言组成的集合也给出一个特殊的表述.
定义 1.10 语言的集合称为类 (class),用正体加粗表示,例如类 $\mathbf{R} = \left\lbrace {L_1}, {L_2}, \dots\right\rbrace$.
定义 1.11 对于类 $\mathbf{R} = \left\lbrace {L_1}, {L_2}, \dots\right\rbrace$,将 $\left\lbrace \overline{L_1}, \overline{L_2}, \dots\right\rbrace$ 记为 $\mathbf{co\text{-}R}$,称为 $\mathbf{R}$ 类的补类 (complement class).
注意,$\mathbf{co\text{-}R}$ 不是 $\mathbf{R}$ 相对于 $\mathbb{L}$ 补集,而是 $\mathbf{R}$ 中每一个元素相对于 $\Sigma^\ast$ 的补集组成的集合.
例如,所有语言类 $\mathbb{L} = \left\lbrace \emptyset, \lbrace\epsilon\rbrace, \lbrace a\rbrace, \lbrace \epsilon, a\rbrace, \lbrace b\rbrace, \lbrace \epsilon, b\rbrace, \lbrace a, b\rbrace, \lbrace \epsilon, a, b\rbrace, \lbrace aa\rbrace, \dots, \Sigma^\ast \right\rbrace$,它的补集 $\mathbb{L}\setminus\mathbb{L}$ 是空集,但是它的补类 $\mathbf{co\text{-} }\mathbb{L} = \left\lbrace \overline{\emptyset}, \overline{\lbrace\epsilon\rbrace},\dots, \overline{\Sigma^\ast}\right\rbrace = \left\lbrace \Sigma^\ast, \Sigma^\ast\setminus\lbrace\epsilon\rbrace,\dots, \emptyset\right\rbrace = \mathbb{L}$,是它自己.也就是 $\mathbb{L}=\mathbf{co\text{-} }\mathbb{L}$.
1.3 判定与识别
定义 1.12 对于一台图灵机 $\text{M}\in\mathbb{TM}$,符号集 $\Sigma$,若对任何 $\omega\in\Sigma^\ast$ 作为输入,$\text{M}$ 一定停机,即一定接受 $\omega$ 或者拒绝 $\omega$,则将所有接受的 $\omega$ 组成的集合记为语言 $L$,称 $\text{M}$ 判定 (decide) $L$.
定义 1.13 如果图灵机 $\text{M}$ 对任何 $\omega\in\Sigma^\ast$ 作为输入,$\text{M}$ 接受 $\omega$ 当且仅当 $\omega\in{L}$,则称 $\text{M}$ 识别 (recognize) $L$.
和上文判定的区别是,$\text{M}$ 识别 $L$ 时不一定停机,即在 $\omega\notin{L}$ 时,$\text{M}$ 可以拒绝,也可以死循环.
与推论 1.2 类似,输入为多个参数时,同样可以编码为一个字符串.此时,该输入属于语言 $L$ 可以记作 $\left(\omega_1, \omega_2, \dots, \omega_n\right) \in L$,语言 $L$ 可以记作 $L\left(\omega_1, \omega_2, \dots, \omega_n\right)$.
每个图灵机一定识别一种语言(只考虑接受,不停机和拒绝不用处理;哪怕对于全部输入,都拒绝或不停机,也识别了语言 $L=\emptyset$),但只有一定停机的的图灵机才能识别并判定一种语言.
定义 1.14 对于一个语言 $L$,如果存在图灵机判定它,则称 $L$ 是可判定 (decidable) 或可计算 (computable) 的.如果语言 $\overline{L}$ 是可判定的,则称语言 $L$ 是可判定补集 (co-decidable) 或可计算补集 (co-computable) 的.
定义 1.15 对于一个语言 $L$,如果存在图灵机识别它,则称 $L$ 是可识别 (recognizable) 的.如果语言 $\overline{L}$ 是可识别的,则称语言 $L$ 是可识别补集 (co-recognizable) 的.
推论 1.16 由定义可知,
- $L$、$\overline{L}$ 可识别 $\Leftrightarrow$ $L$ 可判定 $\Leftrightarrow$ $\overline{L}$ 可判定
- $L$、$\overline{L}$ 至少有一个不可识别 $\Leftrightarrow$ $L$ 不可判定 $\Leftrightarrow$ $\overline{L}$ 不可判定
换成补集(co-)描述方法即为
- $L$ 可识别且可识别补集 $\Leftrightarrow$ $L$ 可判定 $\Leftrightarrow$ $L$ 可判定补集
- $L$ 不可识别或不可识别补集 $\Leftrightarrow$ $L$ 不可判定 $\Leftrightarrow$ $L$ 不可判定补集
最后,由于 $\left\vert\mathbb{L}\right\vert = \mathfrak{c} \gg \aleph_0 = \left\vert\mathbb{TM}\right\vert$,而一种图灵机最多只能识别、判定一种语言,所以
推论 1.17 有无穷多的语言是不可识别且不可判定的.
1.4 偏函数与图灵机等价性
首先引入数学中的偏函数,它是函数的超集,定义为
定义 1.18 若 $f: S \rightarrow Y$ 是映射,$S$ 可为空集,取 $S$ 的超集 $X$,$S \subseteq X$,$f$ 在 $X\setminus S$ 上无意义见下注释 (not defined) ,则称 $f: X \rightarrow Y$ 为偏函数 (partial function),或称为部分函数.$X$ 沿用函数的叫法称为定义域 (domain),$S$ 称为意义域见下注释 (domain of definition).显然,$f(x)$ 有意义当且仅当 $x \in S$.如果偏函数 $f$ 在所有定义域上均有意义,即 $S = X$,则称 $f$ 为全函数 (total function),或简单称为函数 (function).
中文中 domain 翻译为“定义域”,与英文采取的方式不同,因此 domain of definition 不能简单翻译为“定义的定义域”,我暂且翻译为“意义域”(并非官方翻译).not defined 也因此称为“无意义”(而非“无定义”,否则“定义域内无定义”在文字上自相矛盾).
这里最后得到的函数定义,和常规的函数定义一致.不过在某些常规定义中,定义域 $X$ 不可为空集(此处可以,略有差异).但我们后文讨论的定义域 $X$ 均不为空集,故无影响.
上面的定义即是在说,偏函数是“可能在定义域 $X$ 的部分值上无意义的函数”,但要注意,不是“一定在定义域 $X$ 的部分值上无意义的函数”.也就是说,偏函数包括了函数(全函数)和存在某些无意义值的情况(可称为“真偏函数”).
当然,偏函数可在全部定义域 $X$ 上无意义(即意义域 $S$ 为空集).
再次强调,全函数 $=$ 函数 $\subseteq$ 偏函数.后文不使用全函数这一名词,仅使用函数和偏函数.
根据代码经验可知,不同的代码可以完成完全相同的工作.事实上,图灵机也是类似的,也有很多不同的图灵机在做完全相同的事情,为了描述这种现象,我们定义
定义 1.19 如果两个图灵机 $\text{M}_1, \text{M}_2\in\mathbb{TM}$ 对任何 $\omega$ 作为输入,都有
\[\left\lbrace \begin{aligned} & \text{M}_1(\omega) = \text{M}_2(\omega) \Leftrightarrow \text{M}_{1}(\omega)\downarrow \;\Leftrightarrow \text{M}_{2}(\omega)\downarrow \\ & \text{M}_1(\omega)\uparrow \; \Leftrightarrow \text{M}_2(\omega)\uparrow \\ \end{aligned} \right.\]则称 $\text{M}_1, \text{M}_2$ 等价,记作 $\text{M}_1 \cong \text{M}_2$,在一些要展示参数位置的情况,可以写成 $\text{M}_1(\omega) \cong \text{M}_2(\omega)$.
再定义偏函数和图灵机的关系,
定义 1.20 如果定义在 ${\Sigma^\ast} \to {\Sigma^\ast}$ 上的偏函数 $f(x)$ 满足
\[\left\lbrace \begin{aligned} & f(x) = \text{M}(x) \Leftrightarrow \text{M}(x)\downarrow \\ & f(x) \text{ is not defined} \Leftrightarrow \text{M}(x)\uparrow \\ \end{aligned} \right.\]则称 $f, \text{M}$ 等价,记作 $f \cong \text{M}$ 或 $f(x) \cong \text{M}(x)$.
定义 1.21 如果定义在 ${\Sigma^\ast} \to {\Sigma^\ast}$ 上的偏函数 $f_1(x), f_2(x)$ 满足
\[\left\lbrace \begin{aligned} & f_1(x) = f_2(x) \Leftrightarrow f_1(x)\text{ is defined} \Leftrightarrow f_2(x)\text{ is defined} \\ & f_1(x) \text{ is not defined} \Leftrightarrow f_2(x) \text{ is not defined} \\ \end{aligned} \right.\]则称 $f_1, f_2$ 等价,记作 $f_1 \cong f_2$ 或 $f_1(x) \cong f_2(x)$.
与推论 1.2 类似,以上的输入和输出都可以是多参数 ${\lbrace\Sigma^\ast \cup \mathbb{N}\rbrace}^{k_1} \to {\lbrace\Sigma^\ast \cup \mathbb{N}\rbrace}^{k_2}$ 的.
定义 1.22 对于偏函数 $f$,如果存在 $\text{M}$ 使得 $\text{M} \cong f$,则偏函数 $f$ 称为偏可计算 (partial computable) 或偏可递归 (partial recursive) 的;如果 $\text{M}$ 一定停机,则偏函数 $f$ 称为可计算 (computable) 或可递归 (recursive) 的.偏可计算、偏可递归也可称为部分可计算、部分可递归;可计算、可递归也可称为全可计算、全可递归.
若图灵机一定停机,说明与其等价的 $f$ 在所有输入上有定义,也即,
推论 1.23 若偏函数 $f$ 可计算,则 $f$ 是函数.
与语言的定义进行对比,偏函数的可计算性和语言的可计算性是类似的,都需要存在一个不停机的图灵机,和它等价或判定它.但是偏函数的偏可计算性与语言的可识别性稍有不同.可识别语言如果包含 $x$,则必须接受;如果不包含 $x$,对应的图灵机在 $x$ 上可以拒绝或不停机.偏可计算函数如果在 $x$ 上有定义,输出必须相同;如果无定义,它对应的图灵机也必须在 $x$ 上不停机.
和语言的结论一样,由于偏函数是 ${\Sigma^\ast} \to {\Sigma^\ast}$ 的,其势为 ${\aleph_0}^{\aleph_0}\left( = 2^{\aleph_0}\right)$proof,因而也有结论
推论 1.23 有无穷多的偏函数不是偏可计算的,亦不是可计算的.
下面我们看看偏可计算函数和图灵机的关系.为方便,偏可计算函数的集合暂记为 $\mathbb{PCF}$.
一方面,任何图灵机都或者输出或者不停机,因此对于任何图灵机 $\text{M}$,可以构造偏函数 $f$.如果输入 $\omega$ 满足 $\text{M}(\omega)\downarrow$,令 $f(\omega)=\text{M}(\omega)$;如果输入不停机,令 $f$ 在 $\omega$ 上无意义(not defined).同时此 $f$ 是偏可计算的.因此,$\forall\,\text{M}\in\mathbb{TM}, \exists f\in\mathbb{PCF}, f \cong \text{M}$.
另一方面,由定义,$\forall f\in\mathbb{PCF}, \exists\, \text{M}\in\mathbb{TM}, \text{M} \cong f$.
同时,可以用类似的方法证明传递性,即 $f_1 \cong \text{M}, f_2 \cong \text{M} \Rightarrow f_1 \cong f_2$,以及 $\text{M}_1 \cong f, \text{M}_2 \cong f \Rightarrow \text{M}_1 \cong \text{M}_2$.
我们考虑图灵机关于等价运算 $\cong$ 的商集 $\mathbb{TM}\;/\cong$,和偏可计算函数关于等价的商集 $\mathbb{PCF}\;/\cong$.其每个等价类用代表元分别记为集合 $\lbrack\text{M}\rbrack\in\left(\mathbb{TM}\;/\cong\right)$ 和集合 $\lbrack{f}\rbrack\in\left(\mathbb{PCF}\;/\cong\right)$.
如果 $f \cong \text{M}$,由于等价类中的输出和停机完全相同,因此,$\forall\,\text{M}’\in\lbrack\text{M}\rbrack, \forall f’\in\lbrack{f}\rbrack$,有 $f’\cong \text{M}’$.此时我们称 $\lbrack{f}\rbrack \cong \lbrack\text{M}\rbrack$.再结合上述论断,易知,图灵机等价商集与偏可计算函数等价商集,可以通过等价运算一一对应.或简称为,
定理 1.24 图灵机与偏可计算函数等价.
最后,参考链接,我们可以证明存在一个通用图灵机,即
定理 1.25 存在通用图灵机 $\text{U}$,对任意 $\langle{\text{M} }\rangle$ 和 $\omega$ 输入,使得 $\text{U}(\langle{\text{M} }\rangle, \omega) \cong \text{M}(\omega)$.
1.A 本节符号表
符号 | 含义 |
---|---|
$\mathbb{TM}$ | 图灵机集合 |
$\text{M}$ | 图灵机 |
$\text{M}(\omega)\downarrow$ | 图灵机 $\text{M}$ 在输入 $\omega$ 时停机 |
$\text{M}(\omega)\uparrow$ | 图灵机 $\text{M}$ 在输入 $\omega$ 时不停机 |
$\text{M}(\omega) = \sigma$ | 图灵机 $\text{M}$ 在停机时输出 $\sigma$ |
$\text{M}\left(\omega_1, \omega_2, \dots, \omega_n\right)$ | 图灵机 $\text{M}$ 以 $\omega_1, \omega_2, \dots, \omega_n$ 作为输入 |
$\text{M}_n$ | 自然数 $n$ 对应的图灵机 |
$\langle{\text{M} }\rangle$ | 图灵机 $\text{M}$ 对应的自然数 |
$\mathbb{L}$ | 语言集合 |
$L$ | 语言 |
$\overline{L}$ | 语言的补 |
$\mathbf{R}$ | 语言类 |
$\mathbf{co\text{-}R}$ | 语言类 $\mathbf{R}$ 的补类 |
$f(x) \cong \text{M}(x)$ | 等价关系 |
1.B 本节例子
1,一个可识别可判定的例子:回文语言 $L_{pal}$
证明:图灵机首先在工作带照抄一遍输入,然后将输入带和工作带的指针分别移动到头和尾,然后分别向右向左运动并比较两个字符是否相同.如果遇到不相同的则拒绝,如果遇到空白(扫描完毕)则接受.
2,一个可识别不可判定的例子:$A_{\mathbb{TM} }$
$A_{\mathbb{TM} }$ 判断图灵机 $\text{M}$ 是否接受一个输入 $\omega$,$(\langle{\text{M} }\rangle,\omega) \in A_{\mathbb{TM} }$ 当且仅当 $\text{M}$ 图灵机接受 $\omega$
证明:对角线方法,参考链接.此证明方法十分重要.
性质 1.26 $A_{\mathbb{TM} }$ 可识别,但不可判定.
3,一个不可识别不可判定的例子:$\overline{A_{\mathbb{TM} } }$
证明:由于 $A_{\mathbb{TM} }$ 可识别不可判定,根据前文定义中的直接推论,$L$、$\overline{L}$ 至少有一个不可识别 $\Leftrightarrow$ $L$ 不可判定,因此 $\overline{A_{\mathbb{TM} } }$ 不可识别,亦不可判定.