欢迎访问 生活随笔!

生活随笔

当前位置: 首页 > 编程资源 > 编程问答 >内容正文

编程问答

水管工游戏

发布时间:2025/3/19 编程问答 41 豆豆
生活随笔 收集整理的这篇文章主要介绍了 水管工游戏 小编觉得挺不错的,现在分享给大家,帮大家做个参考.

最近小哼又迷上一个叫做水管工的游戏。游戏的大致规则是这样的。一块矩形土地被分为N * M的单位正方形,现在这块土地上已经埋设有一些水管,水管将从坐标为(1,1)左上角左部边缘,延伸到(N,M)右下角右部边缘。水管只有2种,如下图所示。

每种管道将占据一个单位正方形土地。你现在可以旋转这些管道,使得构成一个管道系统,即创造一条从(1,1)到(N,M)的连通管道。标有树木的方格表示这里没有管道。如下图:一个4*5的土地中(4,2)处有一个树木。

我们可以旋转其中的一些管道,使之构成一个连通的管道系统,如下图。

如果通过旋转管道可以使之构成一个连通的管道系统,就输出铺设的路径,否则粗出impossible。

输入格式:

输入的第一行为两个整数N和 M(都不超过10),接下来的N行,每行有M个整数,表示地图中的每一小格。其中0表示树木,1~6分别表示管道的六种不同的摆放方式
输出格式:

样例 1 :

输入:
5 4
5 3 5 3
1 5 3 0
2 3 5 1
6 1 1 5
1 5 5 4
输出:
(1,1) (1,2) (2,2) (3,2) (3,3) (3,4) (4,4) (5,4)

#include <stdio.h> #include <iostream> #include <utility> #include <queue> using namespace std; int g[15][15]; bool book[15][15]; int flag=0; int n,m; typedef pair<int,int> P; queue<P>q; void dfs(int x,int y,int front){if(x==n&&y==m+1){flag=1;int cnt=q.size();for(int i=0; i<cnt; i++){//cout<<"q size"<<" "<<q.size()<<endl;P t; t=q.front(); q.pop();printf(" (%d,%d)", t.first, t.second);}return ;}if(x<1||x>n||y<1||y>m) return ;if(book[x][y]==1) return ;book[x][y]=1;P t; t.first=x,t.second=y; q.push(t);if(g[x][y]==5||g[x][y]==6){if(front==1) dfs(x,y+1,1);if(front==2) dfs(x+1,y,2);if(front==3) dfs(x,y-1,3);if(front==4) dfs(x-1,y,4);}if(g[x][y]>=1&&g[x][y]<=4){if(front==1) dfs(x+1,y,2),dfs(x-1,y,4);if(front==2) dfs(x,y+1,1),dfs(x,y-1,3);if(front==3) dfs(x-1,y,4),dfs(x+1,y,2);if(front==4) dfs(x,y+1,1),dfs(x,y-1,3);}book[x][y]=0; q.pop();return ; } int main(){cin>>n>>m;for(int i=1; i<=n; i++)for(int j=1; j<=m; j++)cin>>g[i][j];dfs(1,1,1);if(flag==0) cout<<"impossible"<<endl;return 0; }

总结

以上是生活随笔为你收集整理的水管工游戏的全部内容,希望文章能够帮你解决所遇到的问题。

如果觉得生活随笔网站内容还不错,欢迎将生活随笔推荐给好友。