鱼C论坛

 找回密码
 立即注册
查看: 1961|回复: 2

骑士周游问题求助

[复制链接]
发表于 2020-4-6 11:31:25 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 慕容紫小英 于 2020-4-7 08:54 编辑

这是我自己写的代码,编译没有问题

  1. #include <stdio.h>

  2. int stop(int (*knight)[8]);
  3. int check(int i,int j,int (*knight)[8]);
  4. void tour(int i,int j,int step,int (*knight)[8]);

  5. int stop(int (*knight)[8])//判断停止条件,当棋盘都被填满则停止
  6. {
  7.         int i,j;
  8.         for(i = 0;i < 8;i++)
  9.         {
  10.                 for(j = 0;j < 8;j++)
  11.                 {
  12.                         if(knight[i][j] == 0)
  13.                         {
  14.                                 return 1;
  15.                         }
  16.                 }
  17.         }

  18.         return 0;
  19. }

  20. void tour(int i,int j,int step,int (*knight)[8])//决定下一步
  21. {
  22.         int t;
  23.         t = check(i,j,knight);//先进行检查
  24.        
  25.         if(t = 0)//不可进行下一步则直接结束
  26.         {
  27.                 return;       
  28.         }
  29.        
  30.         switch(t)
  31.         {
  32.                 case 1:i -= 2,j -= 1;
  33.                 case 2:i -= 2,j += 1;
  34.                 case 3:i -= 1,j += 2;
  35.                 case 4:i += 1,j += 2;
  36.                 case 5:i += 2,j += 1;
  37.                 case 6:i += 2,j -= 1;
  38.                 case 7:i += 1,j -= 2;
  39.                 case 8:i -= 1,j -= 2;
  40.         }
  41.         knight[i][j] = ++step;
  42.         tour(i,j,step,knight);       
  43. }

  44. int check(int i,int j,int (*knight)[8])//检查knight[i][j]是否可以进行下一步
  45. {
  46.         int m,n,k;
  47.         for(k = 1;k < 9;k++)
  48.         {
  49.                 m = i,n = j;
  50.                 switch(k)
  51.                 {       
  52.                         case 1:m -= 2,n -= 1;
  53.                         case 2:m -= 2,n += 1;
  54.                         case 3:m -= 1,n += 2;
  55.                         case 4:m += 1,n += 2;
  56.                         case 5:m += 2,n += 1;
  57.                         case 6:m += 2,n -= 1;
  58.                         case 7:m += 1,n -= 2;
  59.                         case 8:m -= 1,n -= 2;
  60.                 }
  61.                 if(knight[m][n] == 0)//如果可以,则函数返回k值
  62.                 {
  63.                         return k;
  64.                 }
  65.         }
  66.        
  67.         return 0;//不能进行下一步则返回0
  68. }

  69. int main()
  70. {
  71.         int i,j,row,col,step = 1;
  72.         int knight[8][8];
  73.        
  74.         for(i = 0;i < 8; i++)
  75.         {
  76.                 for(j = 0;j < 8; j++)
  77.                 {
  78.                         knight[i][j] = 0;
  79.                 }
  80.         }

  81.         printf("请输入起始的位置(例如第1行第1列):");
  82.         scanf("第%d行第%d列",&row,&col);

  83.         knight[row-1][col-1] = step;
  84.        
  85.         while(stop(knight))//用stop函数控制循环结束
  86.         {
  87.                 tour(row-1,col-1,step,knight);
  88.         }

  89.         for(i = 0;i < 8;i++)
  90.         {
  91.                 for(j = 0;j < 8;j++)
  92.                 {
  93.                         printf("%d ",knight[i][j]);
  94.                 }
  95.         }

  96.         return 0;
  97. }
复制代码


但运行很多次都是这个结果
[W_UA4E%R}MIPE$[2{01TBL.png
我自己找不出原因了
希望大佬们可以帮我看看,感激不尽
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2020-4-9 07:55:10 | 显示全部楼层
求助各位路过的大佬
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-3-16 22:00:37 | 显示全部楼层
楼主解决了吗
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-4-30 21:12

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表