图灵机原理

2024-01-10 10:04
文章标签 原理 图灵机

本文主要是介绍图灵机原理,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

图灵机原理

组成

一个两头无延伸的纸带,一个读写头,一本操作手册。

格式

纸带上只能写 0 和 1。

读写头可以在纸带上左右移动。

手册的每一页都有“一个判断”和“三个操作”:

  • 一个判断:判断读写头当前位置的值是 0 还是 1,根据不同的值,选择不同的操作(每页都有两组动作,分别对应 0 和 1 的情况,每组动作都执行三个操作)。

  • 三个操作:1、如何修改当前位置的值(0 或 1),2、如何移动读写头(左、右、原地不动),3、翻到指定的手册页

启动

在开始执行前,需要做一些初始化操作:

  1. 把程序代码(0 和 1 的序列)写到纸带上,纸带上要有初始信息给读写头读取。

  2. 将读写头定位到初始位置(程序要求的初始位置),

  3. 指定操作手册(一个二维数组)

  4. 指定手册的初始页面(程序要求的初始页面)。

  5. 指定一个或多个手册页作为“停机”页面,当到达该页面时,则停止运行。

运行

  1. 翻到手册的初始页面,

  2. 如果当前页面是“停机”页面,则停止运行。

  3. 如果不是“停机”页面,则判断当前位置的值是 0 还是 1,并选择相应的动作。

  4. 根据动作要求,修改当前位置的值。

  5. 根据动作要求,移动读写头。

  6. 根据动作要求,翻到指定的手册页面。

  7. 回到第 2 步重复执行。

JavaScript 示例

// 图灵机// program  : 纸带(存储程序和执行结果)
// position : 初始位置
// manual   : 操作手册(二维数组)
// page     : 初始页面
// stop     : 停机页面(数组,可指定多个停机页面)
function run(program, position, manual, page, stop) {// 通过查询手册得到的“新值”和“移动方向”let value, direction;// 循环直到页码为停机页面while (! stop.includes(page)) {// 读取当前位置的值value = program[position];// 查询手册,获取新值、移动方向、新页面[value, direction, page] = manual[page][value];// 赋值program[position] = value;// 移动position += direction;};
}// 操作手册(该手册实现加法运算)
const plus_manual = {// 旧页面: {旧值: [新值, 移动方向, 新页面]}0: {0: [1,  1, 1], 1: [1,  1, 0]},1: {0: [0, -1, 2], 1: [1,  1, 1]},2: {0: [0,  0, 3], 1: [0,  0, 3]},
};// 手册其实就是一个二维数组
//const plus_manual = [
//  // [新值, 移动方向, 新页面]
//  [[1,  1, 1], [1,  1, 0]],
//  [[0, -1, 2], [1,  1, 1]],
//  [[0,  0, 3], [0,  0, 3]],
//];// 程序(计算4+3)
let program = [1,1,1,1,0,1,1,1,0];// 启动
run(program, 0, plus_manual, 0, [3]);// 显示结果
console.log(program);// 结果 = 7
// [1, 1, 1, 1, 1, 1, 1, 0, 0]// 这个图灵机是以 bit 为移动单位,每个格子只能存储 0 和 1,而实际的计算机是以 Byte(8 bit)为移动单位,每个格子可以存储 0-255 的值。

视频演示:https://www.bilibili.com/video/BV1br4y1N762/
视频演示:https://www.bilibili.com/video/BV1VS4y1a7JD/

这篇关于图灵机原理的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/590412

相关文章

Spring Boot 实现 IP 限流的原理、实践与利弊解析

《SpringBoot实现IP限流的原理、实践与利弊解析》在SpringBoot中实现IP限流是一种简单而有效的方式来保障系统的稳定性和可用性,本文给大家介绍SpringBoot实现IP限... 目录一、引言二、IP 限流原理2.1 令牌桶算法2.2 漏桶算法三、使用场景3.1 防止恶意攻击3.2 控制资源

Python中使用uv创建环境及原理举例详解

《Python中使用uv创建环境及原理举例详解》uv是Astral团队开发的高性能Python工具,整合包管理、虚拟环境、Python版本控制等功能,:本文主要介绍Python中使用uv创建环境及... 目录一、uv工具简介核心特点:二、安装uv1. 通过pip安装2. 通过脚本安装验证安装:配置镜像源(可

Mysql的主从同步/复制的原理分析

《Mysql的主从同步/复制的原理分析》:本文主要介绍Mysql的主从同步/复制的原理分析,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录为什么要主从同步?mysql主从同步架构有哪些?Mysql主从复制的原理/整体流程级联复制架构为什么好?Mysql主从复制注意

Nacos注册中心和配置中心的底层原理全面解读

《Nacos注册中心和配置中心的底层原理全面解读》:本文主要介绍Nacos注册中心和配置中心的底层原理的全面解读,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录临时实例和永久实例为什么 Nacos 要将服务实例分为临时实例和永久实例?1.x 版本和2.x版本的区别

apache的commons-pool2原理与使用实践记录

《apache的commons-pool2原理与使用实践记录》ApacheCommonsPool2是一个高效的对象池化框架,通过复用昂贵资源(如数据库连接、线程、网络连接)优化系统性能,这篇文章主... 目录一、核心原理与组件二、使用步骤详解(以数据库连接池为例)三、高级配置与优化四、典型应用场景五、注意事

电脑系统Hosts文件原理和应用分享

《电脑系统Hosts文件原理和应用分享》Hosts是一个没有扩展名的系统文件,当用户在浏览器中输入一个需要登录的网址时,系统会首先自动从Hosts文件中寻找对应的IP地址,一旦找到,系统会立即打开对应... Hosts是一个没有扩展名的系统文件,可以用记事本等工具打开,其作用就是将一些常用的网址域名与其对应

Dubbo之SPI机制的实现原理和优势分析

《Dubbo之SPI机制的实现原理和优势分析》:本文主要介绍Dubbo之SPI机制的实现原理和优势,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Dubbo中SPI机制的实现原理和优势JDK 中的 SPI 机制解析Dubbo 中的 SPI 机制解析总结Dubbo中

Android与iOS设备MAC地址生成原理及Java实现详解

《Android与iOS设备MAC地址生成原理及Java实现详解》在无线网络通信中,MAC(MediaAccessControl)地址是设备的唯一网络标识符,本文主要介绍了Android与iOS设备M... 目录引言1. MAC地址基础1.1 MAC地址的组成1.2 MAC地址的分类2. android与I

Spring框架中@Lazy延迟加载原理和使用详解

《Spring框架中@Lazy延迟加载原理和使用详解》:本文主要介绍Spring框架中@Lazy延迟加载原理和使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、@Lazy延迟加载原理1.延迟加载原理1.1 @Lazy三种配置方法1.2 @Component

spring IOC的理解之原理和实现过程

《springIOC的理解之原理和实现过程》:本文主要介绍springIOC的理解之原理和实现过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、IoC 核心概念二、核心原理1. 容器架构2. 核心组件3. 工作流程三、关键实现机制1. Bean生命周期2.