poj2243+poj1915骑士问题
2243是骑士问题,八个格子的,BFS,因为要最短路经,所以没有用A*,A*跑不出来,太慢了,因为要搜索到所有解啊!一直更新最优,而BFS,一层一层搜索,第一次得到的便是最短的了!300格子,标记的话,BFS遍历所有时间复杂度也算可以!500MS过!稍微剪枝即可!时间注意!要标记每层已经走过的情况时候要在入队的时候标记!大大降低复杂度!因为出队的时候,有些已经在队里了,但是还没有被标记,现在又让他入队!
1915,也是简单BFS过的,暴搜即可。标记一下。但是先用启发搜索怎么也过不了,TLE,用跑2W次就结束,但是WA,悲剧,用欧几里得距离作启发函数啊,奇怪,在几步之内到达目标附近,可能不是最优解了,因为这样不能像一层一层那样标记了,只能更新最小的情况!很多剪枝的时候要注意语句顺序!还有更新与剪枝的顺序!
#include<iostream> //bfs
#include<string>
#include<queue>
#include<cstring>
using namespace std;
int absnum(int x,int y)
{
if(x>y) return x-y;
else return y-x;
}
bool mark[8][8];
int a[8][8];
int f[8][2]={-2,1,-1,2,1,2,2,1,2,-1,1,-2,-1,-2,-2,-1};
int minpath=15;
struct xy
{
int x,y;
int count;
};
void bfs(string from,string end)
{
queue<xy>q;
xy start;
start.x=from[0]-'a';
start.y=from[1]-'1';
start.count=0;
q.push(start);
int endx=end[0]-'a';
int endy=end[1]-'1';
if((start.x==endx&&absnum(start.y,endy)==1)||(start.y==endy&&absnum(start.x,endx)==1))
{
minpath=3;return;
}
while(!q.empty())
{
xy getfront=q.front();q.pop();
mark[getfront.x][getfront.y]=1;
if(getfront.count>6)return; //无启发可以这样,一层一层,最多走7次。
if(getfront.x==endx&&getfront.y==endy)
{
if(minpath>getfront.count)minpath=getfront.count;
}
for(int i=0;i<8;i++)
{
xy next(getfront);
next.x+=f[i][0];
next.y+=f[i][1];
if(next.x>=0&&next.x<8&&next.y>=0&&next.y<8&&mark[next.x][next.y]==0)
{
if(next.count>minpath)continue; //已经多了就不用了
next.count++;
q.push(next);
mark[next.x][next.y]=1; //在这里标记! }
}
}
}
int main()
{
string from,end;
while(cin>>from>>end)
{
minpath=15;
memset(mark,0,sizeof(mark));
bfs(from,end);
cout<<"To get from "<<from<<" to "<<end<<" takes "<<minpath<<" knight moves."<<endl;
}
return 0;
}
#include<iostream> //bfs1915爆搜过
#include<string>
#include<queue>
#include<cstring>
#include<cmath>
using namespace std;
int absnum(int x,int y)
{
if(x>y) return (x-y);
else return (y-x);
}
int mark[301][301];
int f[8][2]={-2,1,-1,2,1,2,2,1,2,-1,1,-2,-1,-2,-2,-1};
int minpath=300;
struct xy
{
int x,y;
int count;
double juli;
bool operator <(const xy &a)const
{
return a.juli<juli;
}
};
double hamit(xy f,xy e)
{
double res=0;
int tx=absnum(f.x,e.x);
int ty=absnum(f.y,e.y);
res=sqrt(0.0+tx*tx+ty*ty);
return res;
}
xy from,end;int daxiao;
void bfs(xy from,xy end)
{
priority_queue<xy>q;
xy start;
start.x=from.x;
start.y=from.y;
start.count=0;
start.juli=hamit(start,end);
q.push(start);
mark[start.x][start.y]=-1;
int counted=0;
while(!q.empty())
{
xy getfront=q.top();
counted++;
q.pop();
if(counted>10000)
{
if(hamit(getfront,end)>6)continue;
}
if(getfront.x==end.x&&getfront.y==end.y)
{
if(minpath>getfront.count)
{
minpath=getfront.count;
}
continue;
}
for(int i=0;i<8;i++)
{
xy next(getfront);
next.x+=f[i][0];
next.y+=f[i][1];
if(next.x>=0&&next.x<daxiao&&next.y>=0&&next.y<daxiao&&next.count<mark[next.x][next.y])
{
next.juli=hamit(next,end);
next.count++;
if(next.count>=minpath)continue; //比最优差,剪枝!
if(next.count>daxiao/2+3)continue;
if(mark[next.x][next.y]>next.count)
{
mark[next.x][next.y]=next.count;
}
if(next.x==end.x&&next.y==end.y)
{
if(minpath>next.count)
{
minpath=next.count;
}
continue;
}
q.push(next);
}
}
}
return;
}
int main()
{
int na;cin>>na;
while(na--)
{
cin>>daxiao;
cin>>from.x>>from.y>>end.x>>end.y;
minpath=daxiao;
memset(mark,0x3f3f3f3f,sizeof(mark));
bfs(from,end);
cout<<minpath<<endl;
}
return 0;
}
#include<iostream> //bfs,A*/WA不解ing
#include<string>
#include<queue>
#include<cstring>
#include<cmath>
using namespace std;
int absnum(int x,int y)
{
if(x>y) return (x-y);
else return (y-x);
}
int mark[301][301];
int f[8][2]={-2,1,-1,2,1,2,2,1,2,-1,1,-2,-1,-2,-2,-1};
int minpath=300;
struct xy
{
int x,y;
int count;
double juli;
bool operator <(const xy &a)const
{
return a.juli<juli;
}
};
double hamit(xy f,xy e)
{
double res=0;
int tx=absnum(f.x,e.x);
int ty=absnum(f.y,e.y);
res=sqrt(0.0+tx*tx+ty*ty);
return res;
}
xy from,end;int daxiao;
void bfs(xy from,xy end)
{
priority_queue<xy>q;
xy start;
start.x=from.x;
start.y=from.y;
start.count=0;
start.juli=hamit(start,end);
q.push(start);
mark[start.x][start.y]=-1;
// int counted=0;
while(!q.empty())
{
xy getfront=q.top();
// counted++;
//cout<<counted<<"kkk"<<endl;
q.pop();
/* if(counted>20000) //到达2W次,差不多可以出来!
{
return;
}*/
// cout<<getfront.count<<":"<<getfront.x<<"-"<<getfront.y<<endl;
// if( mark[getfront.x][getfront.y]>getfront.count) mark[getfront.x][getfront.y]=getfront.count;
for(int i=0;i<8;i++)
{
xy next(getfront);
next.x+=f[i][0];
next.y+=f[i][1];
if(next.x>=0&&next.x<daxiao&&next.y>=0&&next.y<daxiao)
//有优先队列后已经不是BFS本质,步数多的以及访问过,少的还可访问!不是简单标记!
{
next.juli=hamit(next,end);
next.count++;
if(next.count>=mark[next.x][next.y])continue; //注意这几个语句之间顺序!continue很重要!
mark[next.x][next.y]=next.count;
if(next.x==end.x&&next.y==end.y)
{
if(minpath>next.count)
{
minpath=next.count;
}
continue;
}
if(next.count>=minpath)continue; //比最优差,剪枝!
// if(next.count>daxiao/2+3)continue;
q.push(next);
}
}
}
return;
}
int main()
{
int na;cin>>na;
while(na--)
{
cin>>daxiao;
cin>>from.x>>from.y>>end.x>>end.y;
minpath=daxiao;
memset(mark,0x3f3f3f3f,sizeof(mark));
bfs(from,end);
cout<<minpath<<endl;
}
return 0;
}
poj2243+poj1915骑士问题的更多相关文章
- COGS746. [网络流24题] 骑士共存
骑士共存问题«问题描述:在一个n*n个方格的国际象棋棋盘上,马(骑士)可以攻击的棋盘方格如图所示.棋盘 上某些方格设置了障碍,骑士不得进入. «编程任务:对于给定的n*n个方格的国际象棋棋盘和障碍标志 ...
- 【BZOJ1671】[Usaco2005 Dec]Knights of Ni 骑士 BFS
[Usaco2005 Dec]Knights of Ni 骑士 Description 贝茜遇到了一件很麻烦的事:她无意中闯入了森林里的一座城堡,如果她想回家,就必须穿过这片由骑士们守护着的森林.为 ...
- 骑士游历/knight tour - visual basic 解决
在visual baisc 6 how to program 中文版第七章的练习题上看到了这个问题,骑士游历的问题. 在8x8的国际象棋的棋盘上,骑士(走法:一个方向走两格,另一个方向一格)不重复走完 ...
- BZOJ1085: [SCOI2005]骑士精神 [迭代加深搜索 IDA*]
1085: [SCOI2005]骑士精神 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 1800 Solved: 984[Submit][Statu ...
- BZOJ 1040 【ZJOI2008】 骑士
Description Z国的骑士团是一个很有势力的组织,帮会中汇聚了来自各地的精英.他们劫富济贫,惩恶扬善,受到社会各界的赞扬.最近发生了一件可怕的事情,邪恶的Y国发动了一场针对Z国的侵略战争.战火 ...
- 【BZOJ-1040】骑士 树形DP + 环套树 + DFS
1040: [ZJOI2008]骑士 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 3312 Solved: 1269[Submit][Status ...
- BZOJ1040 [ZJOI2008]骑士
Description Z国的骑士团是一个很有势力的组织,帮会中汇聚了来自各地的精英.他们劫富济贫,惩恶扬善,受到社会各 界的赞扬.最近发生了一件可怕的事情,邪恶的Y国发动了一场针对Z国的侵略战争.战 ...
- BFS 骑士的移动
骑士的移动 题目链接:http://acm.hust.edu.cn/vjudge/contest/view.action?cid=83498#problem/E 题目: Description A f ...
- LA 3523 圆桌骑士
题目链接:http://vjudge.net/contest/141787#problem/A http://poj.org/problem?id=2942 此题很经典 知识点:DFS染色,点-双连通 ...
随机推荐
- mySQL ODBC 在windows 64位版上的驱动问题
1,问题的起源 某次编辑一个asp文件,其中访问mysql数据库的连接字符串如下: "driver={mysql odbc 3.51 driver};server=localhost;uid ...
- 位bit,字节byte,K,M,G(转)
字节是由8个位所组成,可代表一个字符(A~Z).数字(0~9).或符号(,.?!%&+-*/),是内存储存数据的基本单位.1 byte = 8 bit 1 KB = 1024 bytes1 ...
- 洛谷 U10206 Cx的治疗
题目背景 「Cx的故事」众所周知,Cx是一个宇宙大犇.由于Cx在空中花园失足摔下,导致他那蕴含着无穷智慧的大脑受到了严重的损伤,许多的脑神经断裂.于是,Cx的wife(有么?)决定请巴比伦最好的医师治 ...
- Docker Hello World容器运行报错的解决办法
费了好大力气从Docker官网下载了Docker Community Editor的安装镜像,Docker.dmg, 总共将近500MB,双击进行安装: 命令行里使用docker version查看版 ...
- 利用CWinThread实现跨线程父子MFC窗口
利用CWinThread实现跨线程父子MFC窗口 MFC对象只能由创建该对象的线程访问,而不能由其他线程访问. 不遵守该准则将导致断言(assertion)或者无法预知的程序行为等运行期错误. 在多线 ...
- WebDriverException: Message: unknown error: Chrome failed to start: crashed
the last answer WebDriverException: Message: unknown error: Chrome failed to start: crashed
- Dubbo框架的说明
说实话,自己现在做的项目中有用到dubbo,但是我所负责的那一个模块,并没有涉及到dubbo,想学习一下dubbo,之前是没有学习完,这次继续... 一.背景知识总结 二.服务治理 三.Dubbo架构 ...
- SqlSugar直接执行Sql
参考:http://www.codeisbug.com/Doc/8/1132 我的思路: 1.数据库中写好sql 2.用SqlSugar直接执行sql,获取DataTable的数据 3.DataTab ...
- 洛谷P2802 回家
贱呼呼的搜索题 这个最贱的还是在于路途的标记,大部分的题目路途的标记是直接标记即可也就是说我走过了这个点,那么这个点标记上以后不再走,这个题不是,我走过了,但是我可能回了血我又继续走 所以说我们标记的 ...
- Linux内核学习总览
断断续续学习操作系统已经有大半年时间了,一直想系统地梳理一下. 正好借助<深入Linux内核架构> (Wolfgang Manuere 著,郭旭 译)汇总一下. 首先基础框架篇,Linux ...