zoukankan      html  css  js  c++  java
  • UVa 10653

      题目大意:给你一个二维迷宫,给定入口和出口,找出最短路径。

      无权图上的单源最短路,用BFS解决。

     1 #include <cstdio>
     2 #include <queue>
     3 #include <cstring>
     4 using namespace std;
     5 #define MAXN 1100
     6 
     7 int G[MAXN][MAXN], dist[MAXN*MAXN];
     8 const int dir[4][2] = {{-1, 0}, {0, -1}, {0, 1}, {1, 0}};
     9 
    10 int main()
    11 {
    12 #ifdef LOCAL
    13     freopen("in", "r", stdin);
    14 #endif
    15     int R, C;
    16     while (scanf("%d%d", &R, &C) && (R || C))
    17     {
    18         int k;
    19         scanf("%d", &k);
    20         memset(G, 0, sizeof G);
    21         for (int i = 0; i < k; i++)
    22         {
    23             int r, n;
    24             scanf("%d%d", &r, &n);
    25             for (int j = 0; j < n; j++)
    26             {
    27                 int x;
    28                 scanf("%d", &x);
    29                 G[r][x] = 1;
    30             }
    31         }
    32         int x, y;
    33         scanf("%d%d", &x, &y);
    34         int src = x*C + y;
    35         scanf("%d%d", &x, &y);
    36         int dest = x*C + y;
    37         queue<int> q;
    38         memset(dist, -1, sizeof dist);
    39         q.push(src);
    40         dist[src] = 0;
    41         while (!q.empty())
    42         {
    43             int u = q.front();
    44             q.pop();
    45             if (u == dest)  break;
    46             int x = u / C;
    47             int y = u % C;
    48             for (int i = 0; i < 4; i++)
    49             {
    50                 int dx = x + dir[i][0], dy = y + dir[i][1];
    51                 int v = dx * C + dy;
    52                 if (dx >= 0 && dx < R && dy >= 0 && dy < C && G[dx][dy] == 0 && dist[v] == -1)
    53                 {
    54                     dist[v] = dist[u] + 1;
    55                     q.push(v);
    56                 }
    57             }
    58         }
    59         printf("%d
    ", dist[dest]);
    60     }
    61     return 0;
    62 }
    View Code
  • 相关阅读:
    Android theme应用主题实现
    CSS_复习
    复习_数字与字符串
    网络编程
    JAVA--多线程
    File类
    c#中new hisase关键字
    内存泄漏、程序崩溃的排除办法
    解决跨线程问题的几种办法
    c#接口
  • 原文地址:https://www.cnblogs.com/xiaobaibuhei/p/3326814.html
Copyright © 2011-2022 走看看