UVA 1600 Patrol Robert 巡逻机器人 (启发搜索BFS)
非常适合A*的一道题。
比普通的迷宫问题加一个信息k表示当前穿过的障碍物的数量。
#include<cstdio>
#include<cstring>
#include<queue>
using namespace std;
const int MAX = ; int m,n,k; int C[MAX][MAX][MAX];
int G[MAX][MAX]; int tarx,tary;
struct node
{
int g,h;
int x,y;//对于本题 x+y 越大距离终点越近
int k;
bool operator < (const node& rhs) const{
if(g + h > rhs.g + rhs.h) return true;
if(g + h < rhs.h + rhs.g ) return false;
if(g > rhs.g) return true;
if(g < rhs.g) return false;
return k > rhs.k;
}
void H(){
h = tarx - x+ tary - y;
}
}; node start; #define C(n) C[n.x][n.y][n.k]
#define add(n) C(n) = true
int dx[] = { , , ,-};
int dy[] = { , ,-, }; int bfs()
{
priority_queue<node> q;
memset(C,false,sizeof(C));
q.push(start); add(start);
node cur,nxt;
int i,nx,ny,nk;
while(q.size()){
cur = q.top();q.pop();
if(cur.x == tarx && cur.y == tary) return cur.g;
for(i = ; i < ; i++){
nx = cur.x + dx[i];
ny = cur.y + dy[i];
if(nx >= m || nx < || ny >= n || ny < )continue;
nk = G[nx][ny] ? cur.k+ : ;
if(C[nx][ny][nk] || nk > k) continue;
nxt.x = nx ; nxt.y = ny; nxt.g = cur.g+ ; nxt.k = nk ; nxt.H();
q.push(nxt); add(nxt);
}
}
return -;
} int main()
{
// freopen("in.txt","r",stdin);
int T;
int i,j;
scanf("%d",&T);
while(T--){
scanf("%d%d%d",&m,&n,&k);
for(i = ;i < m; i++)
for(j = ;j < n; j++)
scanf("%d",G[i]+j);
tarx = m-;tary = n-;
start.x = start.y = start.g = start.k = ;
//start.H();
printf("%d\n",bfs());
}
return ;
}
UVA 1600 Patrol Robert 巡逻机器人 (启发搜索BFS)的更多相关文章
- UVA 1600 Patrol Robot(机器人穿越障碍最短路线BFS)
UVA 1600 Patrol Robot Time Limit:3000MS Memory Limit:0KB 64bit IO Format:%lld & %llu ...
- UVA - 1600 Patrol Robot (巡逻机器人)(bfs)
题意:从(1,1)走到(m,n),最多能连续穿越k个障碍,求最短路. 分析:obstacle队列记录当前点所穿越的障碍数,如果小于k可继续穿越障碍,否则不能,bfs即可. #pragma commen ...
- UVa 1600 Patrol Robot (习题 6-5)
传送门: https://uva.onlinejudge.org/external/16/1600.pdf 多状态广搜 网上题解: 给vis数组再加一维状态,表示当前还剩下的能够穿越的墙的次数,每次碰 ...
- UVa 1600 Patrol Robot(三维广搜)
A robot has to patrol around a rectangular area which is in a form of m x n grid (m rows and ncolumn ...
- UVa 1600 Patrol Robot(BFS)
题意: 给定一个n*m的图, 有一个机器人需要从左上角(1,1)到右下角(n,m), 网格中一些格子是空地, 一些格子是障碍, 机器人每次能走4个方向, 但不能连续穿越k(0<= k <= ...
- UVa 1600 Patrol Robot (BFS最短路 && 略不一样的vis标记)
题意 : 机器人要从一个m * n 网格的左上角(1,1) 走到右下角(m, n).网格中的一些格子是空地(用0表示),其他格子是障碍(用1表示).机器人每次可以往4个方向走一格,但不能连续地穿越k( ...
- UVA 1600 Patrol Robot
带状态的bfs 用一个数(ks)来表示状态-当前连续穿越的障碍数: step表示当前走过的步数: visit数组也加一个状态: #include <iostream> #include & ...
- Uva 1600 Patrol Robot (BFS 最短路)
这道题运用的知识点是求最短路的算法.一种方法是利用BFS来求最短路. 需要注意的是,我们要用一个三维数组来表示此状态是否访问过,而不是三维数组.因为相同的坐标可以通过不同的穿墙方式到达. #inclu ...
- UVa 1600 Patrol Robot【BFS】
题意:给出一个n*m的矩阵,1代表墙,0代表空地,不能连续k次穿过墙,求从起点到达终点的最短路的长度 给vis数组再加一维状态,表示当前还剩下的能够穿越的墙的次数,每次碰到墙,当前的k减去1,碰到0, ...
随机推荐
- C# 写 LeetCode easy #7 Reverse Integer
7.Reverse Integer Given a 32-bit signed integer, reverse digits of an integer. Example 1: Input: 123 ...
- lower_bound和upper_bound使用说明
#include <bits/stdc++.h> using namespace std; int main() { ]; ;i<=;i++) { a[i] = i*; } ;i&l ...
- PHP SOAP 提交XML
<?php $xmldata = <<<EOT <soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap. ...
- loadrunner教程系列
loadrunner教程系列,包括windows 环境和linux 环境. 第一讲:环境准备 链接:https://pan.baidu.com/s/1EnLP3ijZ1j1I_ysE1z4CJg 密 ...
- java基础第十二篇之集合、增强for循环、迭代器和泛型
Collection接口中的常用方法: * 所有的子类子接口都是具有的 * 集合的方法:增删改查 * * public boolean add(E e);//添加元素 返回值表示是否添加成功 * pu ...
- 定位之float 同一父元素的float相互影响,float是margin盒子在父元素的padding盒子内
- Domination
题目链接 #include <bits/stdc++.h> using namespace std; typedef long long ll; inline ll read(){ , f ...
- SWT的基本组件使用
1按钮组件(Button) (1)Button组件常用样式 SWT.PUSH按钮 SWT.CHECK多选按钮 SWT.RADIO单选按钮 SWT.ARROW箭头按钮 SWT.NONE默认按钮 SWT. ...
- excel 公式2列合并
=A2&"="&C2 ="UPDATE comm_department SET parent_id='"&D2&"' ...
- 在linux上怎么查看tomcat日志
进入到tomcat的logs文件夹 tail -f catalina.out