设为首页 加入收藏

TOP

HDU 4856 Tunnels
2015-07-24 05:36:40 来源: 作者: 【 】 浏览:6
Tags:HDU 4856 Tunnels

题意:求经过所有的管道的最短路程,管道内的时间不算

思路:首先BFS处理出管道出口到其他管道入口的距离,然后在队友的指导下明白了状态转移

#include 
  
   
#include 
   
     #include 
    
      #include 
     
       #include 
      
        using namespace std; const int MAXN = 16; const int INF = 0x3f3f3f3f; struct Node { int sx, sy, ex, ey; } node[MAXN]; struct point { int x, y, step; }; char g[MAXN][MAXN]; int n, m, dp[1<
       
         q; point a; a.x = sx, a.y = sy, a.step = 0; q.push(a); vis[sx][sy] = 1; while (!q.empty()) { point cur = q.front(); q.pop(); if (cur.x == ex && cur.y == ey) { dis[from][to] = cur.step; return; } for (int i = 0; i < 4; i++) { int nx = cur.x + dx[i]; int ny = cur.y + dy[i]; if (g[nx][ny] == '#' || vis[nx][ny]) continue; if (nx > 0 && nx <= n && ny > 0 && ny <= n) { vis[nx][ny] = 1; point b; b.x = nx, b.y = ny; b.step = cur.step + 1; q.push(b); } } } } int main() { while (scanf("%d%d", &n, &m) != EOF) { for (int i = 1; i <= n; i++) scanf("%s", g[i]+1); for (int i = 0; i < m; i++) scanf("%d%d%d%d", &node[i].sx, &node[i].sy, &node[i].ex, &node[i].ey); memset(dis, -1, sizeof(dis)); for (int i = 0; i < m; i++) for (int j = 0; j < m; j++) bfs(i, j, node[i].ex, node[i].ey, node[j].sx, node[j].sy); memset(dp, -1, sizeof(dp)); for (int i = 0; i < m; i++) dp[1<
        
          dp[all-1][i]) ans = dp[all-1][i]; } printf("%d\n", ans); } return 0; }
        
       
      
     
    
   
  



】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇HDU4565 So Easy! 矩阵快速幂外加.. 下一篇POJ 3255 Roadblocks (次短路问题)

评论

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