计算理论是计算机应用的基础,理论和应用缺一而不可。

---- 目录 ----

C01 自动机
C02 有穷自动机
C03 正则表达式与正则语言
C04 正则语言的性质
C05 上下文无关文法及上下文无关语言
C06 下推自动机
C07 上下文无关语言的性质
C08 图灵机
C09 不可判定性
C10 难解问题
C11 其他问题类
 
---- C01 自动机 ----
  • 有穷自动机(FA)的两个重要因素是状态跳转,状态是数据/环境,跳转是函数/响应。
  • 自动机的结构表示法有两种,一种是正则表达式,正则表达式(RE)和有穷自动机(FA)是等价的,前者只是后者的结构记号而已,另一种是文法,通常指的是上下文无关文法,用来构建编译器的语法分析器。
  • 可判定性是研究计算机能做什么不能做什么的,计算机能解决的问题称为“可判定的”,反之则为“不可判定的”,难解性是指问题的解决难度是容易的还是复杂的,复杂度为多项式的问题称为“易解的”/“可计算的”(P问题),反之则为“难解的”/“不可计算的”(NP问题)。
  • 证明分为演绎证明和归纳证明,演绎证明是基于推导(前提->结论)的命题树,“如果那么”是单向的,“当且仅当”是双向的,命题当且仅当逆否命题(若A则B<->若非B则非A),反证法(证明A与非B矛盾)就是基于此的,反例法是用来推翻错误命题的,归纳证明分为基础部分/初始部分(S(0)成立)和归纳部分/推导部分(S(n)成立->S(n+1)成立),结构归纳法是基于递归定义的,所谓的“结构”是指某个递归定义的结构。从哲学上认为,演绎法归纳法是两个不同的过程,前者是从一般到个别的应用过程,后者是从个别到一般的总结过程,而我们这里强调的演绎是寻找前提和结论之间的联通路径,归纳是从部分到整体、从容易到困难的递归推导。
  • 自动机理论的中心概念有字母表、串和语言,字母表(A)是字母的集合,(S)是字母的序列,语言(L)是串的集合,判定问题是判定某个串是否属于某个语言的问题,语言和判定问题其实是相同的东西,它们都划出了“是”与“不是”的界线。
 
---- C02 有穷自动机 ----
  • 有穷自动机(FA)是基于状态和控制的,“控制”是制定状态跳转的规则,控制有“确定的”(只有一个状态)和“非确定的”(可以多个状态),所以有穷自动机有确定型有穷自动机(DFA)和非确定型有穷自动机(NFA)两种,正则表达式是有穷自动机的代数记号,它与有穷自动机是等价的,正则语言是描述有穷自动机的语言。
  • 确定型有穷自动机(DFA)由有穷个状态的集合(Q)、有穷个输入符号的集合(A)、转移函数(T)、初始状态(q0)和接受状态的集合(F)五部分组成,DFA可以用数学公式描述:DFA=(Q, A, T, q0, F),也可以用转移图转移表描述,转移函数是基于某个输入符号的,扩展转移函数是基于某个输入符号序列的,DFA的语言L(DFA)={S|T(q0,S)属于F},输入一个符号序列,DFA可以接受拒绝(判定性)。
  • 确定型有穷自动机(DFA)只有一个状态,而非确定型有穷自动机(NFA)可以多个状态,从而具备了一定的“猜测”能力。与DFA一样,NFA也是由五部分组成,只是转移函数T的返回是状态的集合(DFA的只是一个状态),也就是说,DFA只是NFA的一个特例而已,在设计上NFA会比DFA更加简单和自然,NFA的语言L(NFA)={S|T(q0,S)与F的交集非空},NFA与DFA是等价的(也即是L(NFA)等价于L(DFA)),通过子集构造,我们可以把NFA的状态集合作为DFA的状态,把NFA转为为等价的DFA,但换来的是指数增长的状态数,我认为两者等价应该取其较简者,在设计上,如果缺少转移,可以额外添加一个“死状态”。
  • 带ε的非确定型有穷自动机(ε-NFA)是NFA的一个变种,ε指的是空串,它提供了很大的便利性,ε-NFA与NFA的不同也在于转移函数上,ε-NFA的转移函数可以接收ε作为输入符号(允许空输入),从状态q出发通过ε转移能够到达的所有状态的集合称为状态q的ε闭包(或ε闭集)(ECLOSE(q)),通过融合了ε闭包的子集构造,我们可以看到ε-NFA与DFA其实也是等价的。
  • 有穷自动机的理论最初来源于神经网路的研究,研究神经网络可能有助于发现比有穷自动机更为复杂的模型。
 
---- 
 

自动机理论、语言和计算导论 by John E. Hopcroft的更多相关文章

  1. [Coursera][计算导论与C语言基础][Week 10]对于“数组应用练习”课后习题的思考题的一些想法

    (首先,关于Honor Code,我咨询过了Help Center,分享课后练习的思考题的想法是可以的(注意不是代码),但要标明引用,引用格式来源于https://guides.lib.monash. ...

  2. C语言中计算变量占用内存空间

    C语言中计算变量占用内存空间 在C语言中通常用[sizeof]运算符计算变量占内存空间,如下面的例子:

  3. 李洪强漫谈iOS开发[C语言-041]-计算月份天数

    李洪强漫谈iOS开发[C语言-041]-计算月份天数 

  4. C 语言实例 - 计算标准偏差

    C 语言实例 - 计算标准偏差 计算标准偏差. 实例 #include <stdio.h> #include <math.h> float calculateSD(float ...

  5. C 语言实例 - 计算一个数的 n 次方

    C 语言实例 - 计算一个数的 n 次方 计算一个数的 n 次方,例如: ,其中 为基数, 为指数. 实例 - 使用 while #include <stdio.h> int main() ...

  6. C 语言实例 - 计算自然数的和

    C 语言实例 - 计算自然数的和 自然数是指表示物体个数的数,即由0开始,,,,,,……一个接一个,组成一个无穷的集体,即指非负整数. 实例 - 使用 for #include <stdio.h ...

  7. Problem Q: C语言习题 计算该日在本年中是第几天

    Problem Q: C语言习题 计算该日在本年中是第几天 Time Limit: 1 Sec  Memory Limit: 128 MBSubmit: 4572  Solved: 2474[Subm ...

  8. C 语言实例 - 计算两个时间段的差值

    C 语言实例 - 计算两个时间段的差值 C 语言实例 C 语言实例 计算两个时间段的差值. 实例 #include <stdio.h> struct TIME { int seconds; ...

  9. C 语言实例 - 计算字符串长度

    C 语言实例 - 计算字符串长度 C 语言实例 C 语言实例 计算字符串长度. 实例 - 使用 strlen() #include <stdio.h> #include <strin ...

随机推荐

  1. hihoCoder太阁最新面经算法竞赛18

    比赛链接:http://hihocoder.com/contest/hihointerview27/problems A.Big Plus 模拟水 #include <bits/stdc++.h ...

  2. Java开发中经典的小实例-( 鸡蛋0.1元一个,鸭蛋3元一个,鹅蛋6元一个。求一百元买一百个蛋。)

    public class Test24 {    public static void main(String[] args) {        // 鸡蛋0.1元一个,鸭蛋3元一个,鹅蛋6元一个.求 ...

  3. jsp标签精华(持续更新中)

    <%@ taglib uri="/struts-tags" prefix="s" %> <%@ taglib uri="http:/ ...

  4. linux命令:mkdir命令

    命令参数: -m, --mode=模式,设定权限<模式> (类似 chmod),而不是 rwxrwxrwx 减 umask -p, --parents  可以是一个路径名称.此时若路径中的 ...

  5. python成长之路【第七篇】:面向对象

    概述 面向过程:根据业务逻辑从上到下写垒代码 函数式:将某功能代码封装到函数中,日后便无需重复编写,仅调用函数即可 面向对象:对函数进行分类和封装,让开发“更快更好更强...” 面向对象三大特性 面向 ...

  6. js实现手机号码和身份证号码校验

    <script type="text/javascript"> function checkform() { var re; var ss = document.get ...

  7. RecyleView 简析

    LayoutManager.Adapter是必须设置的(不设置将无法显示数据---不执行onCreateViewHolder()等方法) ItemDecoration\ItemAnimator是可选的 ...

  8. iOS开发 火星坐标转百度坐标

    CLLocationCoordinate2D coor = CLLocationCoordinate2DMake(latitude, longitude);//原始坐标 //转换 google地图.s ...

  9. 23.APR/Native

    Apache Portable Runtime (APR) based Native library for Tomcat Table of Contents Introduction Install ...

  10. Python学习笔记只列表和元组

    一.成员资格 1.检查某个字符是否在某个字符串中:'a' in 'absent' 2.获取数组的长度.最大.最小值: numbers=[100,54,345] len(numbers) //长度 ma ...