POJ 2488 深搜dfs、
题意:模拟国际象棋中马的走棋方式,其实和中国象棋的马走的方式其实是一样的,马可以从给定的方格棋盘中任意点开始,问是否能遍历全部格子,能的话输出字典序最小的走棋方式,否则输出impossible
思路:只要能遍历全部的格子,就一定会走A1这个点,而且这个点的字典序是最小的,保证了这点的话还需要保证dfs的8个方向也要按照字典序最小来走,这样就可以确保所走的路径就是字典序最小的
坑爹:自己忘记输出Scenario #i,一连WA了几发,就是不知道自己错在哪里,顺便发一个对照的程序吧我的程序过16MS,他的程序0MS
先贴自己的
#include<cstdio>
#include<cstring>
#include<cmath>
const int qq=;
int vis[qq][qq];
int dx[]={-,-,-,-,,,,},
dy[]={-,,-,,-,,-,};
int map[qq][qq];
int n,m,flag,ans;
int check(int y,int x)
{
if(x<||y<||x>m||y>n||map[y][x])
return ;
return ;
}
void dfs(int y,int x,int step)
{
if(flag) return;
if(check(y,x)) return;
vis[step][]=x;
vis[step][]=y;
if(step==n*m){
flag=;
ans=step;
return;
}
for(int i=;i<;++i){
map[y][x]=;
dfs(y+dy[i],x+dx[i],step+);
map[y][x]=;
}
return;
}
int main()
{
int t,o=;scanf("%d",&t);
while(t--)
{
flag=;
scanf("%d%d",&n,&m);
memset(vis,,sizeof(vis));
memset(map,,sizeof(map));
ans=;
dfs(,,);
printf("Scenario #%d:\n",o++);
if(ans!=n*m){
printf("impossible");
}
else{
for(int i=;i<=ans;++i){
printf("%c",vis[i][]+'A'-);
printf("%d",vis[i][]);
}
}
printf("\n");
if(t!=) printf("\n");
}
return ;
}
#include<cstdio>
.#include<cstring>
.#include<algorithm>
.using namespace std;
.
.int path[][], vis[][], p, q, cnt;
.bool flag;
.
.int dx[] = {-, , -, , -, , -, };
.int dy[] = {-, -, -, -, , , , };
.
.bool judge(int x, int y)
.{
. if(x >= && x <= p && y >= && y <= q && !vis[x][y] && !flag)
. return true;
. return false;
.}
.
.void DFS(int r, int c, int step)
.{
. path[step][] = r;
. path[step][] = c;
. if(step == p * q)
. {
. flag = true;
. return ;
. }
. for(int i = ; i < ; i++)
. {
. int nx = r + dx[i];
. int ny = c + dy[i];
. if(judge(nx,ny))
. {
.
. vis[nx][ny] = ;
. DFS(nx,ny,step+);
. vis[nx][ny] = ;
. }
. }
.}
.
.int main()
.{
. int i, j, n, cas = ;
. scanf("%d",&n);
. while(n--)
. {
. flag = ;
. scanf("%d%d",&p,&q);
. memset(vis,,sizeof(vis));
. vis[][] = ;
. DFS(,,);
. printf("Scenario #%d:\n",++cas);
. if(flag)
. {
. for(i = ; i <= p * q; i++)
. printf("%c%d",path[i][] - + 'A',path[i][]);
. }
. else
. printf("impossible");
. printf("\n");
. if(n != )
. printf("\n");
. }
. return ;
.}
POJ 2488 深搜dfs、的更多相关文章
- POJ 1321 深搜dfs
思路其实挺简单的,为什么我想不到呢!!! 原因分析:(1)题目还是做少了 (2)做题目的时候在放音乐 (3)最近脑袋都不愿意想思路总是想一些无用的 改进:(1)以后做题目坚决不开音乐,QQ直接挂隐身 ...
- 深搜(DFS),Image Perimeters
题目链接:http://poj.org/problem?id=1111 解题报告: 1.这里深搜有一点要注意,对角线上的点,如果为'.',则total不应该增加,因为这不是他的边长. #include ...
- 图的遍历 之 深搜dfs
DFS 遍历 深度优先搜索是一个递归过程,有回退过程. 对一个无向连通图,在访问图中某一起始顶点u 后,由u 出发,访问它的某一邻接顶点v1:再从v1 出发,访问与v1 邻接但还没有访问过的顶点v2: ...
- HDU 2553 N皇后问题(深搜DFS)
N皇后问题 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submi ...
- 深搜(DFS),回溯,Fire Net
题目链接:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=2 解题报告: 这里的深搜有一点不同,就是,在深搜每一个点时,都要深搜每 ...
- 算法学习笔记(六) 二叉树和图遍历—深搜 DFS 与广搜 BFS
图的深搜与广搜 复习下二叉树.图的深搜与广搜. 从图的遍历说起.图的遍历方法有两种:深度优先遍历(Depth First Search), 广度优先遍历(Breadth First Search),其 ...
- 【深搜(DFS)-例题-踏青】-C++
描述 小白和他的朋友周末相约去召唤师峡谷踏青.他们发现召唤师峡谷的地图是由一块一块格子组成的,有的格子上是草丛,有的是空地.草丛通过上下左右 4 个方向扩展其他草丛形成一片草地,任何一片草地中的格子都 ...
- POJ 1190(深搜)
http://poj.org/problem?id=1190 又有好久没做搜索的题了,没想到做一个卡了我那么久,想哭啊. 一个中文题,思路呢也就是搜索呗,一层一层往上面搜,不过这里有两个比较重要的地方 ...
- poj1321 棋盘问题(深搜dfs)
转载请注明出处:http://blog.csdn.net/u012860063? viewmode=contents 题目链接:id=1321">http://poj.org/prob ...
随机推荐
- python-None
今天偶然间,有人问了一个问题,项目中出现了一个这样的错误. 看到后,就想到是前后数据类型不一致.当时他定义了一些默认初始值为None(刚接触python代码,之前是c,java),然后就后边出现了这样 ...
- CSS基础教程:群组化选择器
常常我们的CSS 样式中会有好几个地方需要使用到相同的设定时,一个一个分开写会是一件满累人的工作,重覆性太高且显得冗长,更不好管理....在CSS 语法的基本设定中,就可以把这几个相同设定的选择器合并 ...
- Kafka 集群安装
Kafka 集群安装 环境: Linux 7.X kafka_2.x 在linux操作系统中,kafka安装在 /u04/app目录中 1. 下载 # wget https://mirrors.cnn ...
- spss命令数据整理中compute与record命令的区别
spss命令数据整理中compute与record命令的区别 record修改存在的变量,或者生成新的变量 spss变量定义说明 1.Name:变量名,定义规则与其它软件中的雷同,如第一个字符必须为字 ...
- R语言数据分析利器data.table包—数据框结构处理精讲
R语言数据分析利器data.table包-数据框结构处理精讲 R语言data.table包是自带包data.frame的升级版,用于数据框格式数据的处理,最大的特点快.包括两个方面,一方面是写的快,代 ...
- More Effective C++: 05技术(25-28)
25:将constructor 和 non-member functions 虚化 所谓 virtual constructor是某种函数,视其输入可产生不同类型的对象.比如下面的代码: class ...
- 【JZOJ4855】【NOIP2016提高A组集训第6场11.3】荷花池塘
题目描述 于大夫建造了一个美丽的池塘,用来让自己愉快的玩耍.这个长方形的池子被分割成了M 行 和N 列的正方形格子.池塘中有些地方是可以跳上的荷叶,有些地方是不能放置荷叶也不 能跳上的岩石,其他地方是 ...
- Nacos 发布 1.0.0 GA 版本,可大规模投入到生产环境
经过 3 个 RC 版本的社区体验之后,Nacos 正式发布 1.0.0 GA 版本,在架构.功能和 API 设计上进行了全方位的重构和升级. 1.0.0 版本的发布标志着 Nacos 已经可以大规模 ...
- jquery 即点即改
//在html中建立表单. <table border=""> <th>编号</th> <th>用户名</th> < ...
- Uva 10074【递推dp】
UVa 10074 题意:求01矩阵的最大子0矩阵. http://www.csie.ntnu.edu.tw/~u91029/MaximumSubarray.html#2 这里说的很清楚.先求Larg ...