http://poj.org/problem?id=1128
1 #include<iostream> 2 #include<cstring> 3 #include<cstdio> 4 using namespace std; 5 char str[100]; 6 char map[100][100]; 7 bool vis[100]; 8 int in[100],edge[100][100],r,c; 9 int lx,uy,rx,dy,num; 10 void find(int y,int x){ 11 char ch=map[y][x]; 12 lx=uy=10000; 13 rx=dy=-1; 14 for(int i=0;i<r;i++){ 15 for(int j=0;j<c;j++){ 16 if(map[i][j]==ch){ 17 if(i<uy)uy=i; 18 if(i>dy)dy=i; 19 if(j<lx)lx=j; 20 if(j>rx)rx=j; 21 } 22 } 23 } 24 } 25 void buildmap(){ 26 int i,j,k; 27 num=0; 28 for(i=0;i<r;i++){ 29 for(j=0;j<c;j++){ 30 if(map[i][j]==‘.‘||in[map[i][j]-‘A‘]!=-1)continue; 31 num++; 32 in[map[i][j]-‘A‘]=0; 33 char ch=map[i][j]; 34 find(i,j); 35 for(k=lx;k<=rx;k++){ 36 if(map[uy][k]!=ch)edge[ch-‘A‘][map[uy][k]-‘A‘]=1; 37 if(map[dy][k]!=ch)edge[ch-‘A‘][map[dy][k]-‘A‘]=1; 38 } 39 for(k=uy;k<=dy;k++){ 40 if(map[k][lx]!=ch)edge[ch-‘A‘][map[k][lx]-‘A‘]=1; 41 if(map[k][rx]!=ch)edge[ch-‘A‘][map[k][rx]-‘A‘]=1; 42 } 43 } 44 } 45 for(i=0;i<27;i++){ 46 for(j=0;j<27;j++){ 47 if(edge[i][j]) 48 in[j]++; 49 } 50 } 51 } 52 void dfs(char *s,int cnt){ 53 if(cnt==num){ 54 printf("%s\n",str); 55 return; 56 } 57 int i,j; 58 for(i=0;i<27;i++){ 59 if(in[i]==0&&!vis[i]){ 60 str[cnt]=i+‘A‘; 61 vis[i]=1; 62 for(j=0;j<27;j++){ 63 if(edge[i][j])--in[j]; 64 } 65 dfs(s,cnt+1); 66 vis[i]=0; 67 for(j=0;j<27;j++){ 68 if(edge[i][j])++in[j]; 69 } 70 } 71 } 72 } 73 int main(){ 74 int i,j; 75 while(scanf("%d%d",&r,&c)!=EOF){ 76 memset(str,0,sizeof(str)); 77 memset(vis,0,sizeof(vis)); 78 memset(in,-1,sizeof(in)); 79 memset(edge,0,sizeof(edge)); 80 for(i=0;i<r;i++)scanf("%s",map[i]); 81 buildmap(); 82 dfs(str,0); 83 } 84 return 0; 85 }
原文:http://www.cnblogs.com/SSYYGAM/p/4509311.html