poj2488 A Knight’s Journey

poj2488 A Knight’s Journey

http://poj.org/problem?id=2488

 

题目大意:骑士厌倦了一遍又一遍地看到同样的黑白方块,于是决定去旅行。

世界各地。当一个骑士移动时,他走的是“日”字。骑士的世界是他赖以生存的棋盘。我们的骑士生活在一个棋盘上,它的面积比普通的8 * 8板要小,但它仍然是矩形的。你能帮这个冒险的骑士制定旅行计划吗? 找到一条路,这样骑士每一次都能到每一个广场。骑士可以在棋盘的任何方格上开始和结束。输入从第一行的正整数n开始。下面的行包含n个测试用例。每个测试用例由一个带有两个正整数p和q的单行组成,其中1 <= p * q <= 26。这表示一个p * q棋盘,其中p描述了多少个不同的数1,…p存在,q描述存在多少个不同的字母。这些是拉丁字母表中的第一个q字母:A,…每个场景的输出从包含“Scenario #i:”的一行开始,其中i是从1开始的场景的数量。然后打印一行一行,其中包含了字母顺序的第一路径,它访问棋盘上的所有方块,然后是空行。通过将访问的方块的名称连接起来,可以在一行中给出路径。每个方名称由大写字母和数字组成。

如果不存在这样的路径,那么您应该在一行上输出impossible的内容。

 

也就是说横坐标时是字母(向右为正),纵坐标是数字(向下为正),骑士需要走完全图的方格,并找出包含了字母顺序的第一条路径,那么这就暗示了骑士的起点坐标一定是A1,只有是按字母排序第一个一定是A1。骑士走的是“日”字,那么根据字母排序骑士的横坐标和纵坐标减少或增加的遍历顺序是8个方向(-2,-1)(-2,1)(-1,-2)(-1,2)(1,-2)(1,2)(2,-1)(2,1),这样的遍历顺序,得到的第一条路径一定是按字母顺序的路径。

 

算法思想:回溯法,问题的解空间树是一颗八叉树,分别对应八个方向,设置相应的剪枝函数,1)如果出界,舍弃相应子树;2)如果找到了一条路径(一定是按字母排序的路径),用一个isSoluted记录,如果问题解决,则减去相应子树;3)我们可以用visited[ ][ ]记录该方格被访问,减去相应子树(重复走回路),并在回溯时设为未访问。

 1 #include <cstring>//使用memset()
 2 #include <iostream>
 3 using namespace std;
 4 //按字典排序的行走方向       8叉树
 5 const int dx[8] = { -2, -2, -1, -1, 1, 1, 2, 2 };
 6 const int dy[8] = { -1, 1, -2, 2, -2, 2, -1, 1 };
 7 const int N = 27;
 8 bool visited[N][N];//判断方格是否被访问
 9 struct step {
   //走路的记录
10     char x, y;
11 };
12 step path[N];//记录路径的
13 bool isSoluted;//能否走通
14 int cases, p, q;//记录案例数,p行123... q列ABC...
15 void Backtrade(int x, int y, int t)//x 和 y 为当前坐标 t为深度
16 {
17     path[t].x = x + 'A' - 1;   //转为 char 记录走的路径
18     path[t].y = y + '0';
19     if (t == p * q)//如果有一条路走完全部 则可解 直接退出回溯
20     {
21         isSoluted = true;
22         return;
23     }
24     for (int i = 0; i < 8; i++)
25     {
26         int nx = x + dx[i];
27         int ny = y + dy[i];
28         //剪枝函数 出界 或 已访问过 或 问题已解决 不进入相应子树
29         if (0 < nx && nx <= q && 0 < ny && ny <= p&& !visited[nx][ny] && !isSoluted)
30         {
31             visited[nx][ny] = true;
32             Backtrade(nx, ny, t + 1);
33             visited[nx][ny] = false;//回溯时撤回标记
34         }
35     }
36 }
37 int main()
38 {
39     cin>>cases;
40     for (int c = 1; c <= cases; c++)
41     {
42         isSoluted = false;
43         cin >> p >> q;
44         memset(visited, false, sizeof(visited));
45         visited[1][1] = true;    //从第一个字典序起点开始走
46         Backtrade(1, 1, 1);
47         cout<<"Scenario #"<<c<<":"<<endl;
48         if (isSoluted)
49         {
50             for (int i = 1; i <= p * q; i++)
51                 cout << path[i].x << path[i].y;
52             cout << endl;
53         }
54         else
55             cout<<"impossible"<<endl;
56         cout << endl;
57     }
58     return 0;
59 }

 

转载于:https://www.cnblogs.com/DA799422035/p/8994075.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/101680.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • linux下批量替换文件内容

    linux下批量替换文件内容1、网络上现成的资料  格式:sed-i"s/查找字段/替换字段/g"`grep查找字段-rl路径`  linuxsed批量替换多个文件中的字符串  sed-

    2022年7月26日
    6
  • 单片机_MFRC522射频模块使用方法(含代码)

    单片机_MFRC522射频模块使用方法(含代码)MFRC522射频模块使用方法本文只讲解MFRC522射频模块使用方法(下文简称522模块),不包含原理说明,原理下篇~一、管脚解释522模块总共有8个引脚,除去复位、GND接地、3.3V电源、NC端悬空、SCK时钟端,剩余3个引脚,起数据作用。二、连接方法这里主要使用IIC的方法,相信写过IIC的同学都很熟悉这段代码。不熟悉也没关系,后文会附上52单片机的LCD1602显示UID的实现代码,包含UART测试代码。显而易见,通过总线办法读取数据只需要依照手册写代码就可以读出来,这里官方提供了

    2022年7月26日
    46
  • python进制转换代码_python十六进制转换成十进制

    python进制转换代码_python十六进制转换成十进制本文实例讲述了Python实现的十进制小数与二进制小数相互转换功能。分享给大家供大家参考,具体如下:十进制小数⇒二进制小数乘2取整对十进制小数乘2得到的整数部分和小数部分,整数部分即是相应的二进制数码,再用2乘小数部分(之前乘后得到新的小数部分),又得到整数和小数部分。如此不断重复,直到小数部分为0或达到精度要求为止.第一次所得到为最高位,最后一次得到为最低位如:0.25的二进制0.25*2=…

    2025年11月30日
    6
  • SpringMvc 最新jar包下载[通俗易懂]

    SpringMvc 最新jar包下载[通俗易懂]下载springmvcJar最终下载地址:https://repo.spring.io/simple/libs-release-local/org/springframework/spring/步骤:https://repo.spring.io/simple/libs-release-local/https://repo.spring.io/simple/libs…

    2022年5月14日
    44
  • 粒子群算法(PSO)的Python实现(求解多元函数的极值)

    粒子群算法(PSO)的Python实现(求解多元函数的极值)PSO是寻优算法中比较简单的一种,本文用Python简单实现了PSO算法,用来求解一个五元函数的最大值,并与MATLAB的fmincon函数的运行结果做比较。

    2022年4月29日
    183
  • html 简单的table样式

    html 简单的table样式效果预览:代码:素材图片:cell-blue.jpgcell-greyjpg

    2022年7月3日
    26

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号