Instructions问题算法分析.docVIP

Instructions问题算法分析.doc

  1. 1、本文档共6页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Instructions问题算法分析   摘要:ACM/ICPC(ACM International Collegiate Programming Contest)是ACM国际大学生程序设计竞赛的简称,这是世界计算机领域的一项权威赛事。该文就是针对ACM国际大学生程序设计中的一道题目的解法进行算法分析,道题目的名字叫做“Instructions”。通过对原问题进行理解,通过暴力方法,动态递推法,对原问题进行算法分析和实现,然后对算法进行测试和总结,从而满足题目的要求。   关键词:Instructions;算法; 暴力方法;动态递推法   中图分类号:TP301文献标识码:A文章编号:1009-3044(2008)22-686-02   Algorithm Analysis of the Problem Instructions   MA Biao-biao   (College of Mathematical Sciences, Anhui University,Hefei 230601,China)   Abstract: ACM/ICPC is the abbreviation of ACM International Collegiate Programming Contest. This is authoritative match in the field of computer. This article aims to analyze the algorithm of a problem ofACM/ICPC. The name of this problem is Instructions. Through a detailed understanding, violent means and the method of dynamic recurrence, we analyze, realize and test the original algorithm such that our algorithm meet the requirement of the problem.   Key words: Instructions; algorithm; forcible method; the method of dynamical recurrence   1 问题提出   1.1 题意分析   题目的大意是这样的,一台老的探测机器人,它的任务是对一块土地进行探测,包括了四条指令,分别为“Forward”,“ Turn Left”,“ Turn Right”,“Scan”当输入指令为“Forward”时则机器人向它所面向的方向前进一格;当输入指令为“Turn Left”时,则机器人在原地向左转向;当输入指令为“Turn Right”时,则机器人在原地向右转向;当输入指令为“Scan”时,则机器人探测它所面向的方向的前一块区域。   现在有一台新的机器人代替老的机器人要完成相同的任务,但是它只有两条指令,为“Move”,“Scan”,移动指令可以让机器人朝它所在位置的任何一个方向移动任何的距离,探测指令则可以让机器人探测它四周的任何一块区域。问题是当新的机器人代替老机器人时,如何让转换它们之间的命令。   题目的输出要求是找出旧的指令转换成新的指令后,新指令最少有多少条。并且机器人要求站在同一起点,探测位置和顺序都不能变。   题意如图1所示:   ■   图1   图中,数字表示老的机器人走过的路线,红色的*表示探测的区域,红色的数字表示探测的顺序,可以看出,老的机器人如果要完成上面的命令,要执行8条指令,分别为ForwardForwardTurn LeftForwardScanTurnRight ScanForward,如果是新的机器人完成,则只关心起点位置和探测位置及探测顺序,要完成上面的任务有许多种走法,我们要做的就是找出使得新的指令最少的那种方法,根据图1,我们不难看出,当新机器人在图中#位置进行探测时,所需要的指令都是4条,分别为Move Forward 2 Move Left 1 Scan ForwardScan Right 。探测的区域最多有1000组,并且有10次输入。   1.2 问题模型   根据上面的问题分析,我们可以总结出该问题的问题模型:有最多1000组数据,按顺序记录了探测点的位置,我们假设则每个位置可以直接探测的站位为探测点的上、下、左、右。根据描述,我们可以记录各个站位的坐标,然后把每个站位到后一站位(包括探测过程)所需要的步骤相加,则最后得出到各个站位,探测完成所需要的总步数的所有可能。如图2所示。   2 算法分析   2.1

您可能关注的文档

文档评论(0)

yingzhiguo + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

版权声明书
用户编号:5243141323000000

1亿VIP精品文档

相关文档