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

---- 目录 ----

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. MYSQL转换JSON

    http://51strive.com/ <!DOCTYPE html><html><head><meta charset="UTF-8" ...

  2. 使用IE11抓包,防止在网页跳转时抓包数据被清除的方法

    引:最近在研究使用python实现模拟登陆各大网站,在使用IE11进行抓包分析网站登陆的逻辑结构的时候,发现每次在抓包的时候,当网页跳转的时候,抓包数据会被清除,让我很是郁闷,最终在查阅相关资料以及自 ...

  3. centos使用yum安装mysql

    参考:http://dev.mysql.com/doc/mysql-yum-repo-quick-guide/en/ 1.增加yum数据源 (1.1)从http://dev.mysql.com/dow ...

  4. ElasticSearch学习问题记录——Invalid shift value in prefixCoded bytes (is encoded value really an INT?)

    最近在做一个电商项目,其中商品搜索中出现一个奇怪的现象,根据某个字段排序的时候会出现商品数量减少的情况.按照一般路要么查不出来,要么正常显示,为什么增加了按照销量排序就会出现查询结果减少的情况. 查了 ...

  5. Android开发之各个语言

    Android开发之各个语言 1.进行源码开发遇到一个最基础的问题就是各个语言下的字串翻译,所以我们必须得清楚res文件夹下各个资源文件夹 2.如图:

  6. NodeJS学习笔记 - Express4.x路由操作

    一.为Express添加about路由 1.新建js文件,about.js 2.打开about.js,并输入以下代码: var express=require('express'); var rout ...

  7. C/C++-----------http协议发送字段,文件,单个和多张图片

    关于c/c++ 网络编程,无论在linux还是windows,要说到自由性,和安全性,socket无疑是比较好的!对于socket,因为它的传输协议只有两种tcp和udp,属于网络层,这里我们不去重点 ...

  8. SuperSlide

    今天又接触到另一个新的前端插件,心情美美哒~ SuperSlide 致力于解决网站大部分特效展示问题,使网站代码规范整洁,方便维护更新,官网地址:http://www.superslide2.com/ ...

  9. SQL Server Profiler教程

    SQL Server Profiler是SQL Server企业版自带的一个sql 语句跟踪和分析工具,功能十分强大.熟练地使用它,对我们分析数据库性能问题很有帮助,比如当数据访问使用EF等ORM框架 ...

  10. 14072202(带IK的Recoil)

    [目标] 带IK的Recoil [思路] 1 继承于USkelControlLimb和UGameSkelCtrl_Recoil 2 效果对比  以这个骨骼为例 Recoil Limb 可见,Recoi ...