骑士游历课程设计报告.docVIP

  1. 1、本文档共7页,可阅读全部内容。
  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文档。上传文档
查看更多
骑士游历课程设计报告

一、题目 给你一个8*8的棋盘,骑士的开始位置,结束位置,让你求得骑士从开始位置开始揍到结束位置需要最小的步数是多少注意,骑士走日字输入包含多组数据每一行都是一组开始位置和结束位置,位置由两个字符组成,一个是小写字母(a-h),一个是数字(1-8),起始位置结束位置由一个空格隔开.输出从起始位置到结束位置,骑士所要走过的最小的步数.e2 e4 a1 b2 b2 c3 a1 h8 a1 h7 h8 a1 b1 c3 f6 f6 OUTPUT样例: To get from e2 to e4 takes 2 knight moves. To get from a1 to b2 takes 4 knight moves. To get from b2 to c3 takes 2 knight moves. To get from a1 to h8 takes 6 knight moves. To get from a1 to h7 takes 5 knight moves. To get from h8 to a1 takes 6 knight moves. To get from b1 to c3 takes 1 knight moves. To get from f6 to f6 takes 0 knight moves. 四、算法思想 根据题目,可以设结束位置和开始位置的横坐标和纵坐标之差分别为x和y,设方向向量为(1,2),(2,1),(2,-1),(1,-2)c=(-4a-5b+2x+y)/3,d=(5a+4b-x-2y)/3,那么有a+2b和2x+y模3同余,现在2x+y已知,对于b进行枚举,由于-n/2=b=n/2,进行枚举,对每个知道a模3是多少,进而再对可能的a进行枚举,从而解出c,d进而求出总步数。但是,特别要注意的就是角落的问题。比如a1,b2按上面方法算的是2,实际是4.经过计算知,对于8*8的只有4种情况:a1 b2;a8 b7;g2 h1;g7 h8;对这四种情况单独列举出来就行了。 五、详细设计和主要编码段 程序流程图如下: (1) 由于骑士从开始位置到结束位置所走的步数是一个非负数,所以要对每个方向的次数求绝对值之后再相加,所以,需要声明一个函数,来求绝对值。 int f(int a) //求绝对值 { if (a0) return 0-a; return a; } (2) 当骑士的当开始位置和结束位置分别为a1,b2或a8,b7或g2,h1或g7,h8,这几种特殊情况时,所需要的最小步数不能用算法计算出来,应该单独列举出来,最小的步数为4步。 while (cin s1 s2){ if ((s1==a1 s2==b2) || (s1==b2 s2==a1) || (s1==g2 s2==h1) || (s1==h1 s2==g2)) { cout To get from s1 to s2 takes 4 knight moves. endl; continue; } if ((s1==a8 s2==b7) || (s1==b7 s2==a8) || (s1==g7 s2==h8) || (s1==h8 s2==g7)) { cout To get from s1 to s2 takes 4 knight moves. endl; continue; } (3) 对b,a枚举,然后求出c,d的值 for (b=-4;b=4;b++){ //对b枚举 m=y+2*x-2*b+30; //a模3的余数 m%=3; for (a=m-6;a=m+6;a+=3){ //对a枚举 c=(2*x+y-4*a-5*b)/3; //求出c和d d=(5*a+4*b-x-2*y)/3; } (4)数据的输出:输出所走的最小的步数。 六、上机调试情况记录 错误及修改:容易出现错误的地方有:子函数和变量的定义,关键字和函数名称的书写,以及一些库函数的规范使用。这些问

文档评论(0)

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

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

1亿VIP精品文档

相关文档