XN*2 Turing机 (python)

XN*2 Turing机 (python)

一、实验目的
1.掌握图灵机的概念和基本结构,理解图灵机的基本指令和编码方式;
2.掌握图灵机的编程方式
二、实验内容
1.对于任意给定的一台Turing机和任意给定的字符串w(w不含空格),编程模拟此Turing机的运行过程,要求输出从运行起的每一步结果。(本次实验内容模拟XN2 Turing机,输入为正整数,经过转化后Turing机对编码执行操作,最终输出一个正整数)
三、算法设计
1.题目分析
对于XN
2 Turing机,输入正整数,执行完操作后,输出正整数。总共涉及以下步骤:
(1)输入一个正整数,将正整数转化成二进制码;
(2)在转化成的二进制码后添加“,” ;
(3)将二进制码转化成XN2 Turing机可执行的编码,将每个“1”用“0”隔开,将“,”替换成“0110”。
(4)执行可执行的编码,输出执行完成后的编码
(5)将编码通过(1)(2)(3)的逆向操作,转化成正整数
2.算法设计
(1)本次实验采用python编程,在python3.7中输入都为str类型,因此通过强制转化,将输入的str类型的正整数转化为int型。在int型中用内置函数bin()将正整数转化成二进制,其类型为str型,且以“0b”开头,使用replace()用“0”将“0b”替换,即可得到二进制码串。
(2)使用str类的方法,为二进制码串加上“,”。
(3)通过仔细观察和研究发现,将二进制码串转化成XN
2 Turing机可执行的编码形式,将二进制码串中的“1”用“10”替换,二进制码中的“0”保持不变,将“,”用“0110”替换即可。使用replace()函数可完成上述操作。
(4)为了XN2 Turing机执行中便于对串中字符的改变,将str类型的串转化为列表(便于值的修改),同时在执行过程中串的长度不够用于执行,通过研究发现XN2 Turing机在0110之后所需的0的个数不会超过正整数二进制码的位数n,通过for循环使用append()函数为列表末端添加n个0.
(5)列表list1用于存储可执行的编码,列表list2用于存储XN2 Turing机的内态,通过循环读出list1中的每个数据和其索引(下标),通过数据值和内态完成Turing的运转及内态的改变,通过数据的索引修改数据值。
(6)XN
2 Turing机执行完毕后得到编码列表,为了便于之后操作,将列表转化成str类型。
(7)每个串执行完成后,在其后端必定有子串“0110”且在其后的值都为0,将子串“0110”用“,”代替,在“,”之后的0全是多余的,影响后序求值,利用
rstrip()函数将指定的0删除(从右端开始删除,直到第一个不为指定字符为止),然后利用replace()将“,”删除,用“1”将串中的所有“10”替换。此时得到二进制码串。
(8)将二进制码串通过int直接转化为十进制的正整数。
四、测试与调试
1.出现错误
在第一次输入正整数后,出现以下错误:
在这里插入图片描述
解决方法:str类型无法被转换,然后再前一行加入查看h类型的函数并输出

在这里插入图片描述
在这里插入图片描述
发现输入的数字为str类型,然后将其强制转化成int类型后无错误。
2.出现错误:
之后发现的运行结果如下:
在这里插入图片描述
Turing机编码未进入循环,或者if中的判断条件未执行
解决方法:首先在for循环下加入对其索引和值的输入,若索引和值出现,则可判断进入循环,未执行判断语句,否则未进入循环中。
在这里插入图片描述
在这里插入图片描述
索引和值出现,可判断未执行判断语句,判断语句中仅出现编码列表中的值和list2中的内态值,从输出中可以看出数据值正确,则问题出现在list2中,对list2的定义和判断语句进行比对,发现定义和判断的值不一致,具体如下:
在这里插入图片描述
在这里插入图片描述
后将定义中的[0]改为0,解决了出现的错误,程序正确运行。

输入正整数3,得到结果6,具体步骤如下:
在这里插入图片描述
在这里插入图片描述
输入正整数6,得到预期结果12,其详细步

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值