题意:因为给出N*N的矩阵了,而且其中肯定有1到n的数,如果这1到n的数中,举例一个数:1,这个数都是都是左右相连的话,并且只有n个1左右相连的话可以,如果这n个数都是这种情况,那么就是good,否则wrong……
思路:这道题还是挺简单的,简单的思想都不变,只是代码可能变得有点长了而已……设一个a字符二维数组,把这些坐标作为这二维数组的下标,然后每行从1开始存,第二行就存2,因为样例中没有第n行,即没有第n个数,所以判断一下,哪个还没存数的就存n,然后dfs就行了……
#include<iostream> #include<cstdio> #include<algorithm> #include<cstring> #include<string> #include<cmath> #include<set> #include<vector> #include<stack> #include<ctime> #include<cstdlib> #define mem(a,b) memset(a,b,sizeof(a)) typedef long long ll; using namespace std; int n,sum,b[102][102]; char a[102][102]; void dfs(int x,int y,char c) { if(a[x][y]=='*'||a[x][y]!=c) return; sum++; a[x][y]='*'; //让其变成初始状态 dfs(x,y+1,c); dfs(x,y-1,c); dfs(x+1,y,c); dfs(x-1,y,c); } int main() { while(cin>>n&&n) { int i,j,x,y,flag=0; sum=0; mem(a,'*'); //初始状态,递归边界的时候反正用得到,赋值的时候赋值的是数字的字母,这样就不会相互影响了 mem(b,0); for(i=1;i<n;i++) for(j=0;j<n;j++) { cin>>x>>y; a[x][y]=i; //刚开始写的是a[x][y]='i',然后结果老错,突然记得以前也有类似的题目,直接赋值用的那个什么码的值,哎呀……晕…… b[x][y]=1; //标记一下哪个已经存了数了 } for(i=1;i<=n;i++) for(j=1;j<=n;j++) //哪个没有被标记过的就赋值n,刚开始想初始化a的时候直接初始化成'n'不就行了,然后想想等下n在边界的话就不好判断了 if(!b[i][j]) a[i][j]=n; //所以还是赋值一下比较好 for(i=1;i<=n;i++) { for(j=1;j<=n;j++) { if(a[i][j]!='*') { sum=0; dfs(i,j,a[i][j]); if(sum!=n) {cout<<"wrong"<<endl;flag=1;break;} //当其不等于n的时候肯定是wrong了,不用再往下判断了 } } if(flag) break; } if(!flag) cout<<"good"<<endl; } return 0; }