图灵机---XN*2

这篇博客介绍了如何使用图灵机模拟XN*2的运算过程,包括图灵机的基本概念、指令编码、算法构造和实现。作者详细阐述了算法的各个步骤,并提到了输入验证和运行时间测试。最后,作者分享了编程实践中的经验和对未来提升的期望。
摘要由CSDN通过智能技术生成

一、实验目的

  1. 掌握图灵机的概念和基本结构,理解图灵机的基本指令和编码方式;

  2. 掌握图灵机的编程方法。
    二、实验内容
    对于任意给定的一台Turing机和任意给定的字符串w ( w不含空格),编程模拟此Turing机的运行过程,要求输出从开始运行起的每一步骤的结果。
    三、实验报告
    1.题目分析
    我准备要做的是XN*2的图灵机模拟。
    (1) 我通过书本知识知道了它的运行过程:
    00->00R:内态和纸带上的数字都为0时,不改变;
    01->10R:内态为0数字为1时,内态变为1数字变为0;
    10->01R:内态为1数字为0时,内态变为0数字变为1;
    11->100R:内态为1数字为1时,内态变为10数字变为0;
    100R->111R:内态为10数字为0时,内态变为11数字变为1;
    110R->01STOP:内态为10数字为1时,内态变为0数字变为0。
    (2) main函数的构造,分为五部分:输入,判断,计算,输出,测试。
    输入输出通过定义的一维数组来存放扩展二进制数字;
    判断通过(a[i]!=‘0’)&&(a[i]!=‘1’)来判断输入数据的正确性;
    计算部分通过if-else语句实现内态变化的输出;
    测试方面通过clock()计时函数判

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值