设为首页 加入收藏

TOP

UVA 11573 - Ocean Currents(BFS+优先队列)
2015-07-20 17:48:56 来源: 作者: 【 】 浏览:1
Tags:UVA 11573 Ocean Currents BFS 优先 队列

UVA 11573 - Ocean Currents

题目链接

题意:给定一个海面,数字分别代表海流方向,顺着海流不用费能量,逆海流要费1点能量,每次询问给一个起点一个终点,问起点到终点耗费的最小能量

思路:广搜,队列用优先队列,每次取能量最低的点出来进行状态的转移

代码:

#include 
  
   
#include 
   
     #include 
    
      using namespace std; const int d[8][2] = {{-1, 0}, {-1, 1}, {0, 1}, {1, 1}, {1, 0}, {1, -1}, {0, -1}, {-1, -1}}; const int N = 1005; int n, m, vis[N][N]; char g[N][N]; struct Node { int x, y, val; Node() {} Node(int x, int y, int val) { this->x = x; this->y = y; this->val = val; } bool operator < (const Node& c) const { return val > c.val; } void read() { scanf("%d%d", &x, &y); } }s, e; int bfs() { priority_queue
     
       Q; s.val = 0; Q.push(s); memset(vis, -1, sizeof(vis)); vis[s.x][s.y] = 0; while (!Q.empty()) { Node u = Q.top(); if (u.x == e.x && u.y == e.y) return u.val; Q.pop(); for (int i = 0; i < 8; i++) { int xx = u.x + d[i][0]; int yy = u.y + d[i][1]; int val = u.val; if (xx < 1 || xx > n || yy < 1 || yy > m) continue; if (i != g[u.x][u.y] - '0') val++; if (vis[xx][yy] == -1 || val < vis[xx][yy]) { vis[xx][yy] = val; Q.push(Node(xx, yy, val)); } } } } int main() { while (~scanf("%d%d", &n, &m)) { for (int i = 1; i <= n; i++) scanf("%s", g[i] + 1); int q; scanf("%d", &q); while (q--) { s.read(); e.read(); printf("%d\n", bfs()); } } return 0; }
     
    
   
  


】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇POJ 1595 素数打表水题 下一篇HDOJ 4821 String

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容:

·C语言结构体怎么直接 (2025-12-24 17:19:44)
·为什么指针作为c语言 (2025-12-24 17:19:41)
·如何较为深入的理解c (2025-12-24 17:19:38)
·Announcing October (2025-12-24 15:18:16)
·MySQL有什么推荐的学 (2025-12-24 15:18:13)