诡异的楼梯 BFS hdu 1180

这题好邪恶啊。做了两个半小时wa得好辛苦。

原因是。。可以停留在空格里的。题意不清啊。

还有就是注意标记。。开了个三维的数组。。分奇数步和偶数步标记。。

最后有可能时间多的先出队。所以要选个最小的时间。。

其实可以用优先队列做。。

艾。。这代码有点太长了。。

#include <stdio.h>
#include
<string.h>
#include
<stdlib.h>
#include
<deque>
#include
<algorithm>
#include
<iostream>

using namespace std;

int a, b, c, d, N, M, t;
char map[50][50];



int hash[3][50][50];

struct node
{
int x, y, t;
}NODE;

int judge( int x, int y)
{
if (x < 1 || x > N || y < 1|| y > M)
return 0;
return 1;
}


void BFS( )
{
int i, j, x1, x2, y1, y2, t2, t1;
deque
<node>q;
memset(hash,
0, sizeof(hash));
NODE.x
= a, NODE.y = b, NODE.t = 0;
//map[a][b]='*';
hash[0][a][b]=1;
t
= 0x7f7f7f7f;
q.push_back(NODE);
while (!q.empty( ))
{
NODE
= q.front( );
q.pop_front( );
x1
= NODE.x, y1 = NODE.y, t1 = NODE.t;
//printf("(%d,%d)->%d\n",x1,y1,t1);
if (x1 == c && y1 == d ) {
if (t1 < t)
t
= t1;
}
//向右移动
x2 = x1 + 0, y2 = y1 + 1, t2 = t1 + 1, NODE.t = 0;
NODE.x
= x2, NODE. y = y2, NODE.t = t2;
if ( judge(x2, y2) && map[x2][y2] != '*' && map[x2][y2] != '-' && map[x2][y2] !='|' && !hash[t2 % 2][x2][y2]) {
hash[t2
%2][x2][y2] = 1;
q.push_back(NODE);
}
else if ( (map[x2][y2] == '-' && t1 % 2 == 0 )|| (map[x2][y2] == '|' && t1 % 2 == 1)) {
//NODE.t;
NODE.y+=1;
y2
+= 1;
if( judge(x2, y2) && map[x2][y2] != '*' && !hash[t2%2][x2][y2])
{
hash[t2
%2][x2][y2] = 1;
q.push_back(NODE);
}
}
else if (map[x2][y2] == '-' || map[x2][y2] == '|') {
//NODE.t;
NODE.y+=1;
y2
+= 1;
NODE.t
++;
t2
++;
if( judge(x2, y2) && map[x2][y2] != '*' && !hash[t2%2][x2][y2])
{
hash[t2
%2][x2][y2] = 1;
q.push_back(NODE);
}
}
//向左移动
x2 = x1 + 0, y2 = y1 - 1, t2 = t1 + 1, NODE.t = 0;
NODE.x
= x2, NODE. y = y2, NODE.t = t2;
if ( judge(x2, y2) && map[x2][y2] != '*' && map[x2][y2] != '-' && map[x2][y2] !='|' && !hash[t2%2][x2][y2]) {
//map[x2][y2] = '*';
hash[t2%2][x2][y2] = 1;
q.push_back(NODE);
}
else if ( (map[x2][y2] == '-' && t1 % 2 == 0 )|| (map[x2][y2] == '|' && t1 % 2 == 1) && !hash[t2%2][x2][y2]) {
//NODE.t++;
NODE.y-=1;
y2
-= 1;
if( judge(x2, y2) && map[x2][y2] != '*')
{
//map[x2][y2]='*';
hash[t2%2][x2][y2] = 1;
q.push_back(NODE);
}
}
else if (map[x2][y2] == '-' || map[x2][y2] == '|') {
//NODE.t;
NODE.y-=1;
y2
-= 1;
NODE.t
++;
t2
++;
if( judge(x2, y2) && map[x2][y2] != '*' && !hash[t2%2][x2][y2])
{
hash[t2
%2][x2][y2] = 1;
q.push_back(NODE);
}
}
//向上移动
x2 = x1 - 1, y2 = y1 , t2 = t1 + 1, NODE.t = 0;
NODE.x
= x2, NODE. y = y2, NODE.t = t2;
if ( judge(x2, y2) && map[x2][y2] != '*' && map[x2][y2] != '-' && map[x2][y2] !='|' && !hash[t2%2][x2][y2]) {
//map[x2][y2] = '*';
hash[t2%2][x2][y2] = 1;
q.push_back(NODE);
}
else if ( (map[x2][y2] == '-' && t1 % 2 == 1 )|| (map[x2][y2] == '|' && t1 % 2 == 0)&& !hash[t2%2][x2][y2]) {
//NODE.t++;
NODE.x-=1;
x2
-= 1;
if( judge(x2, y2) && map[x2][y2] != '*')
{
//map[x2][y2]='*';
hash[t2%2][x2][y2] = 1;
q.push_back(NODE);
}
}
else if (map[x2][y2] == '-' || map[x2][y2] == '|') {
NODE.x
-=1;
x2
-= 1;
NODE.t
++;
t2
++;
if( judge(x2, y2) && map[x2][y2] != '*' && !hash[t2%2][x2][y2])
{
hash[t2
%2][x2][y2] = 1;
q.push_back(NODE);
}
}
//向下移动
x2 = x1 + 1, y2 = y1 , t2 = t1 + 1, NODE.t = 0;
NODE.x
= x2, NODE. y = y2, NODE.t = t2;
if ( judge(x2, y2) && map[x2][y2] != '*' && map[x2][y2] != '-' && map[x2][y2] !='|' && !hash[t2%2][x2][y2]) {

hash[t2
%2][x2][y2] = 1;
q.push_back(NODE);
}
else if ( (map[x2][y2] == '-' && t1 % 2 == 1 )|| (map[x2][y2] == '|' && t1 % 2 == 0)&& !hash[t2%2][x2][y2]) {
NODE.x
+= 1;
x2
+= 1;
if( judge(x2, y2) && map[x2][y2] != '*')
{
hash[t2
%2][x2][y2] = 1;
q.push_back(NODE);
}

}
else if (map[x2][y2] == '-' || map[x2][y2] == '|') {
NODE.x
+=1;
x2
+= 1;
NODE.t
++;
t2
++;
if( judge(x2, y2) && map[x2][y2] != '*' && !hash[t2%2][x2][y2])
{
hash[t2
%2][x2][y2] = 1;
q.push_back(NODE);
}
}
}
}
int main( )
{

int i, j;

while (scanf("%d%d", &N, &M) != EOF)
{
for (i = 1; i <= N; i++)
for( j = 1; j <= M; j++) {
cin
>>map[i][j];
if (map[i][j] == 'S')
{
a
= i;
b
= j;
}
if (map[i][j] == 'T')
{
c
= i;
d
= j;
}
}

BFS( );
printf(
"%d\n",t);
}
return 0;
}

用优先队列。。。

#include <stdio.h>
#include
<string.h>
#include
<stdlib.h>
#include
<deque>
#include
<algorithm>
#include
<iostream>
#include
<queue>

using namespace std;

int a, b, c, d, N, M, t;
char map[50][50];



int hash[3][50][50];

struct node
{
int x, y, t;
bool operator < (const node &A) const
{
return A.t < t;
}
}NODE;




int judge( int x, int y)
{
if (x < 1 || x > N || y < 1|| y > M)
return 0;
return 1;
}


void BFS( )
{
int i, j, x1, x2, y1, y2, t2, t1;
priority_queue
<node>q; //优先队列
memset(hash, 0, sizeof(hash));
NODE.x
= a, NODE.y = b, NODE.t = 0;
//map[a][b]='*';
hash[0][a][b]=1;
t
= 0x7f7f7f7f;
q.push(NODE);
while (!q.empty( ))
{
NODE
= q.top( );
q.pop( );
x1
= NODE.x, y1 = NODE.y, t1 = NODE.t;
//printf("(%d,%d)->%d\n",x1,y1,t1);
if (x1 == c && y1 == d ) {
t
= t1;
break;
}
//向右移动
x2 = x1 + 0, y2 = y1 + 1, t2 = t1 + 1, NODE.t = 0;
NODE.x
= x2, NODE. y = y2, NODE.t = t2;
if ( judge(x2, y2) && map[x2][y2] != '*' && map[x2][y2] != '-' && map[x2][y2] !='|' && !hash[t2 % 2][x2][y2]) {
hash[t2
%2][x2][y2] = 1;
q.push(NODE);
}
else if ( (map[x2][y2] == '-' && t1 % 2 == 0 )|| (map[x2][y2] == '|' && t1 % 2 == 1)) {
//NODE.t;
NODE.y+=1;
y2
+= 1;
if( judge(x2, y2) && map[x2][y2] != '*' && !hash[t2%2][x2][y2])
{
hash[t2
%2][x2][y2] = 1;
q.push(NODE);
}
}
else if (map[x2][y2] == '-' || map[x2][y2] == '|') {
//NODE.t;
NODE.y+=1;
y2
+= 1;
NODE.t
++;
t2
++;
if( judge(x2, y2) && map[x2][y2] != '*' && !hash[t2%2][x2][y2])
{
hash[t2
%2][x2][y2] = 1;
q.push(NODE);
}
}
//向左移动
x2 = x1 + 0, y2 = y1 - 1, t2 = t1 + 1, NODE.t = 0;
NODE.x
= x2, NODE. y = y2, NODE.t = t2;
if ( judge(x2, y2) && map[x2][y2] != '*' && map[x2][y2] != '-' && map[x2][y2] !='|' && !hash[t2%2][x2][y2]) {
//map[x2][y2] = '*';
hash[t2%2][x2][y2] = 1;
q.push(NODE);
}
else if ( (map[x2][y2] == '-' && t1 % 2 == 0 )|| (map[x2][y2] == '|' && t1 % 2 == 1) && !hash[t2%2][x2][y2]) {
//NODE.t++;
NODE.y-=1;
y2
-= 1;
if( judge(x2, y2) && map[x2][y2] != '*')
{
//map[x2][y2]='*';
hash[t2%2][x2][y2] = 1;
q.push(NODE);
}
}
else if (map[x2][y2] == '-' || map[x2][y2] == '|') {
//NODE.t;
NODE.y-=1;
y2
-= 1;
NODE.t
++;
t2
++;
if( judge(x2, y2) && map[x2][y2] != '*' && !hash[t2%2][x2][y2])
{
hash[t2
%2][x2][y2] = 1;
q.push(NODE);
}
}
//向上移动
x2 = x1 - 1, y2 = y1 , t2 = t1 + 1, NODE.t = 0;
NODE.x
= x2, NODE. y = y2, NODE.t = t2;
if ( judge(x2, y2) && map[x2][y2] != '*' && map[x2][y2] != '-' && map[x2][y2] !='|' && !hash[t2%2][x2][y2]) {
//map[x2][y2] = '*';
hash[t2%2][x2][y2] = 1;
q.push(NODE);
}
else if ( (map[x2][y2] == '-' && t1 % 2 == 1 )|| (map[x2][y2] == '|' && t1 % 2 == 0)&& !hash[t2%2][x2][y2]) {
//NODE.t++;
NODE.x-=1;
x2
-= 1;
if( judge(x2, y2) && map[x2][y2] != '*')
{
//map[x2][y2]='*';
hash[t2%2][x2][y2] = 1;
q.push(NODE);
}
}
else if (map[x2][y2] == '-' || map[x2][y2] == '|') {
NODE.x
-=1;
x2
-= 1;
NODE.t
++;
t2
++;
if( judge(x2, y2) && map[x2][y2] != '*' && !hash[t2%2][x2][y2])
{
hash[t2
%2][x2][y2] = 1;
q.push(NODE);
}
}
//向下移动
x2 = x1 + 1, y2 = y1 , t2 = t1 + 1, NODE.t = 0;
NODE.x
= x2, NODE. y = y2, NODE.t = t2;
if ( judge(x2, y2) && map[x2][y2] != '*' && map[x2][y2] != '-' && map[x2][y2] !='|' && !hash[t2%2][x2][y2]) {

hash[t2
%2][x2][y2] = 1;
q.push(NODE);
}
else if ( (map[x2][y2] == '-' && t1 % 2 == 1 )|| (map[x2][y2] == '|' && t1 % 2 == 0)&& !hash[t2%2][x2][y2]) {
NODE.x
+= 1;
x2
+= 1;
if( judge(x2, y2) && map[x2][y2] != '*')
{
hash[t2
%2][x2][y2] = 1;
q.push(NODE);
}

}
else if (map[x2][y2] == '-' || map[x2][y2] == '|') {
NODE.x
+=1;
x2
+= 1;
NODE.t
++;
t2
++;
if( judge(x2, y2) && map[x2][y2] != '*' && !hash[t2%2][x2][y2])
{
hash[t2
%2][x2][y2] = 1;
q.push(NODE);
}
}
}
}
int main( )
{

int i, j;

while (scanf("%d%d", &N, &M) != EOF)
{
for (i = 1; i <= N; i++)
for( j = 1; j <= M; j++) {
cin
>>map[i][j];
if (map[i][j] == 'S')
{
a
= i;
b
= j;
}
if (map[i][j] == 'T')
{
c
= i;
d
= j;
}
}

BFS( );
printf(
"%d\n",t);
}
return 0;
}

转载于:https://www.cnblogs.com/tangcong/archive/2011/08/09/2131978.html

Python网络爬虫与推荐算法新闻推荐平台:网络爬虫:通过Python实现新浪新闻的爬取,可爬取新闻页面上的标题、文本、图片、视频链接(保留排版) 推荐算法:权重衰减+标签推荐+区域推荐+热点推荐.zip项目工程资源经过严格测试可直接运行成功且功能正常的情况才上传,可轻松复刻,拿到资料包后可轻松复现出一样的项目,本人系统开发经验充足(全领域),有任何使用问题欢迎随时与我联系,我会及时为您解惑,提供帮助。 【资源内容】:包含完整源码+工程文件+说明(如有)等。答辩评审平均分达到96分,放心下载使用!可轻松复现,设计报告也可借鉴此项目,该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的。 【提供帮助】:有任何使用问题欢迎随时与我联系,我会及时解答解惑,提供帮助 【附带帮助】:若还需要相关开发工具、学习资料等,我会提供帮助,提供资料,鼓励学习进步 【项目价值】:可用在相关项目设计中,皆可应用在项目、毕业设计、课程设计、期末/期中/大作业、工程实训、大创等学科竞赛比赛、初期项目立项、学习/练手等方面,可借鉴此优质项目实现复刻,设计报告也可借鉴此项目,也可基于此项目来扩展开发出更多功能 下载后请首先打开README文件(如有),项目工程可直接复现复刻,如果基础还行,也可在此程序基础上进行修改,以实现其它功能。供开源学习/技术交流/学习参考,勿用于商业用途。质量优质,放心下载使用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值