/*
============================================================================
Name : Bitmap.c
Author : harini
Version :
Copyright : Your copyright notice
Description : Hello World in C, Ansi-style
============================================================================
*/
#include <stdio.h>
#include <stdlib.h>
struct node
{
int x;
int y;
struct node *next;
}*head=NULL,*temp,*tail,*cur;
int r,c,i,j,k;
int dirx[]={1,0,-1,0};
int diry[]={0,1,0,-1};
int mat[1000][1000],ans[1000][1000],flag[1000][1000];
//fn checks whether the next no is 1,,,and that elt is 0,,,returns 1 if true,,,
/*int next(int **mat,int x1,int y1)
{
int x2,y2;
if(mat[i][j]==0)
{
for(k=0;k<6;k++)
{
x2=i+dirx[k];
y2=j+diry[k];
if(x2<0 || x2>r || y2<0 || y2>c) continue;
if(mat[x2][y2]==0) return 1;
}
}
return 0;
}*/
int nextans(int ans[1000][1000],int x1,int y1)
{
int x2,y2;
if(ans[x1][y1]==0)
{
for(k=0;k<6;k++)
{
x2=x1+dirx[k];
y2=y1+diry[k];
if(x2<0 || x2>r || y2<0 || y2>c) continue;
if(ans[x2][y2]==-1) continue;
if(ans[x2][y2]==1) return 2;
if(ans[x2][y2]==0) return 1;
}
}
return 0;
}
int bitmap()
{
scanf("%d %d",&r,&c);
char matc[r][c];
for(i=0;i<r;i++)
for(j=0;j<c;j++)
{
flag[i][j]=0;
ans[i][j]=-1;
}
for(i=0;i<r;i++)
scanf("%s",matc[i]);
for(i=0;i<r;i++)
for(j=0;j<c;j++)
{
mat[i][j]=matc[i][j]-48;
}
/* for(i=0;i<r;i++)
{
for(j=0;j<c;j++)
printf("%d\t",mat[i][j]);
printf("\n");
}*/
//case1:if the element if 1
int x2,y2;
//printf("i=%d j=%d\n",i,j);
for(i=0;i<r;i++)
for(j=0;j<c;j++)
{
// printf("i=%d j=%d\n",i,j);
if(mat[i][j]==1)// && !flag[i][j])
{
//printf("i=%d j=%d\n",i,j);
flag[i][j]=1;
ans[i][j]=0;
//put all the adjacent elts to 1(int ans) if they are not 0(in mat)
for(k=0;k<4;k++)
{
x2=i+dirx[k];
y2=j+diry[k];
if(x2<0 || y2<0 || x2>=r || y2>=c) continue;
//printf("x2=%d y2=%d\n",x2,y2);
if(mat[x2][y2]==1)
{
printf("x2=%d y2=%d mat val=1\n",x2,y2);
ans[x2][y2]=0;
flag[x2][y2]=1;
}
else
{
printf("x2=%d y2=%d mat val=0\n",x2,y2);
ans[x2][y2]=1;
flag[x2][y2]=1;
}
}
}
}
//case2:element is 0,,,,and next element is one,,,
/*if(next(mat,i,j) && !flag[i][j])
{
ans[i][j]=1;
flag[i][j]=1;
continue;
}
for(i=0;i<r;i++)
for(j=0;j<c;j++)
{
if(!flag[i][j])
{
//if both case fails,,,we add to the stack,,,
temp=(struct node*)malloc(sizeof(struct node));
temp->x=0;
temp->y=0;
temp->next=NULL;
if(head==NULL) head=temp;
for(tail=head;tail->next!=NULL;tail=tail->next);
tail->next=temp;
if(nextans(ans,i,j)==1)
ans[i][j]=1;
else{
*/
int n;
for(i=0;i<r;i++)
for(j=0;j<c;j++)
if(!flag[i][j])
{
while((n=nextans(ans,i,j))!=0)
{
printf("i=%d j=%d",i,j);
flag[i][j]=1;
if(n==2) ans[i][j]+=2;
if(n==1) ans[i][j]+=1;
}
}
printf("\nFLAG\n");
for(i=0;i<r;i++)
{
for(j=0;j<c;j++)
printf("%d\t",flag[i][j]);
printf("\n");
}
printf("\nANSWER,,,\n");
for(i=0;i<r;i++)
{
for(j=0;j<c;j++)
printf("%d\t",ans[i][j]);
printf("\n");
}
return 0;
}
int main()
{
int t;
scanf("%d",&t);
while(t-->0)
{
bitmap();
//scanf("%d %d",&r,&c);
//int ans[r][c];
}
return 0;
}
/*
============================================================================
Name : Bitmap.c
Author : harini
Version :
Copyright : Your copyright notice
Description : Hello World in C, Ansi-style
============================================================================
*/
#include <stdio.h>
#include <stdlib.h>
struct node
{
int x;
int y;
struct node *next;
}*head=NULL,*temp,*tail,*cur;
int r,c,i,j,k;
int dirx[]={1,0,-1,0};
int diry[]={0,1,0,-1};
//fn checks whether the next no is 1,,,and that elt is 0,,,returns 1 if true,,,
/*int next(int **mat,int x1,int y1)
{
int x2,y2;
if(mat[i][j]==0)
{
for(k=0;k<6;k++)
{
x2=i+dirx[k];
y2=j+diry[k];
if(x2<0 || x2>r || y2<0 || y2>c) continue;
if(mat[x2][y2]==0) return 1;
}
}
return 0;
}*/
int nextans(int ans[1000][1000],int x1,int y1)
{
int x2,y2;
if(ans[x1][y1]==0)
{
for(k=0;k<6;k++)
{
x2=x1+dirx[k];
y2=y1+diry[k];
if(x2<0 || x2>r || y2<0 || y2>c) continue;
if(ans[x2][y2]==-1) continue;
if(ans[x2][y2]==1) return 2;
if(ans[x2][y2]==0) return 1;
}
}
return 0;
}
int bitmap()
{
scanf("%d %d",&r,&c);
int mat[r][c],ans[r][c],flag[r][c];
char matc[r][c];
for(i=0;i<r;i++)
for(j=0;j<c;j++)
{
flag[i][j]=0;
ans[i][j]=-1;
}
for(i=0;i<r;i++)
scanf("%s",matc[i]);
for(i=0;i<r;i++)
for(j=0;j<c;j++)
{
mat[i][j]=matc[i][j]-48;
}
/* for(i=0;i<r;i++)
{
for(j=0;j<c;j++)
printf("%d\t",mat[i][j]);
printf("\n");
}*/
//case1:if the element if 1
int x2,y2;
//printf("i=%d j=%d\n",i,j);
for(i=0;i<r;i++)
for(j=0;j<c;j++)
{
// printf("i=%d j=%d\n",i,j);
if(mat[i][j]==1)// && !flag[i][j])
{
//printf("i=%d j=%d\n",i,j);
flag[i][j]=1;
ans[i][j]=0;
//put all the adjacent elts to 1(int ans) if they are not 0(in mat)
for(k=0;k<4;k++)
{
x2=i+dirx[k];
y2=j+diry[k];
if(x2<0 || y2<0 || x2>=r || y2>=c) continue;
//printf("x2=%d y2=%d\n",x2,y2);
if(mat[x2][y2]==1)
{
printf("x2=%d y2=%d mat val=1\n",x2,y2);
ans[x2][y2]=0;
flag[x2][y2]=1;
}
else
{
printf("x2=%d y2=%d mat val=0\n",x2,y2);
ans[x2][y2]=1;
flag[x2][y2]=1;
}
}
}
}
//case2:element is 0,,,,and next element is one,,,
/*if(next(mat,i,j) && !flag[i][j])
{
ans[i][j]=1;
flag[i][j]=1;
continue;
}
for(i=0;i<r;i++)
for(j=0;j<c;j++)
{
if(!flag[i][j])
{
//if both case fails,,,we add to the stack,,,
temp=(struct node*)malloc(sizeof(struct node));
temp->x=0;
temp->y=0;
temp->next=NULL;
if(head==NULL) head=temp;
for(tail=head;tail->next!=NULL;tail=tail->next);
tail->next=temp;
if(nextans(ans,i,j)==1)
ans[i][j]=1;
else{
*/
int n;
for(i=0;i<r;i++)
for(j=0;j<c;j++)
if(!flag[i][j])
{
while((n=nextans(ans,i,j))!=0)
{
printf("i=%d j=%d",i,j);
flag[i][j]=1;
if(n==2) ans[i][j]+=2;
if(n==1) ans[i][j]+=1;
}
}
printf("\nFLAG\n");
for(i=0;i<r;i++)
{
for(j=0;j<c;j++)
printf("%d\t",flag[i][j]);
printf("\n");
}
printf("\nANSWER,,,\n");
for(i=0;i<r;i++)
{
for(j=0;j<c;j++)
printf("%d\t",ans[i][j]);
printf("\n");
}
return 0;
}
int main()
{
int t;
scanf("%d",&t);
while(t-->0)
{
bitmap();
//scanf("%d %d",&r,&c);
//int ans[r][c];
}
return 0;
}
/*
 ============================================================================
 Name        : Bitmap.c
 Author      : harini
 Version     :
 Copyright   : Your copyright notice
 Description : Hello World in C, Ansi-style
 ============================================================================
 */

#include <stdio.h>
#include <stdlib.h>

struct node
{
	int x;
	int y;
	struct node *next;
}*head=NULL,*temp,*tail,*cur;

int r,c,i,j,k;
int dirx[]={1,0,-1,0};
int diry[]={0,1,0,-1};
int mat[1000][1000],ans[1000][1000],flag[1000][1000];

//fn checks whether the next no is 1,,,and that elt is 0,,,returns 1 if true,,,
/*int next(int **mat,int x1,int y1)
{
	int x2,y2;
	if(mat[i][j]==0)
	{
		for(k=0;k<6;k++)
		{
			x2=i+dirx[k];
			y2=j+diry[k];
			if(x2<0 || x2>r || y2<0 || y2>c) continue;
			if(mat[x2][y2]==0) return 1;
		}
	}
	return 0;
}*/

int nextans(int ans[1000][1000],int x1,int y1)
{
	int x2,y2;
	if(ans[x1][y1]==0)
	{
		for(k=0;k<6;k++)
		{
			x2=x1+dirx[k];
			y2=y1+diry[k];
			if(x2<0 || x2>r || y2<0 || y2>c) continue;
			if(ans[x2][y2]==-1) continue;
			if(ans[x2][y2]==1) return 2;
			if(ans[x2][y2]==0) return 1;
		}
	}
	return 0;
}

int bitmap()
{
	scanf("%d %d",&r,&c);
	char matc[r][c];
	for(i=0;i<r;i++)
		for(j=0;j<c;j++)
		{
			flag[i][j]=0;
			ans[i][j]=-1;
		}
	for(i=0;i<r;i++)
			scanf("%s",matc[i]);
	for(i=0;i<r;i++)
		for(j=0;j<c;j++)
		{
			mat[i][j]=matc[i][j]-48;
		}
/*	for(i=0;i<r;i++)
	{
		for(j=0;j<c;j++)
			printf("%d\t",mat[i][j]);
		printf("\n");
	}*/
	//case1:if the element if 1
	int x2,y2;
	//printf("i=%d j=%d\n",i,j);
	for(i=0;i<r;i++)
		for(j=0;j<c;j++)
		{
		//	printf("i=%d j=%d\n",i,j);
			if(mat[i][j]==1)// && !flag[i][j])
			{
				//printf("i=%d j=%d\n",i,j);
				flag[i][j]=1;
				ans[i][j]=0;
				//put all the adjacent elts to 1(int ans) if they are not 0(in mat)
				for(k=0;k<4;k++)
				{
					x2=i+dirx[k];
					y2=j+diry[k];
					if(x2<0 || y2<0 || x2>=r || y2>=c) continue;
					//printf("x2=%d y2=%d\n",x2,y2);
					if(mat[x2][y2]==1)
					{
						printf("x2=%d y2=%d mat val=1\n",x2,y2);
						ans[x2][y2]=0;
						flag[x2][y2]=1;
					}
					else
					{
						printf("x2=%d y2=%d mat val=0\n",x2,y2);
						ans[x2][y2]=1;
						flag[x2][y2]=1;
					}
				}
			}
		}
			//case2:element is 0,,,,and next element is one,,,
			/*if(next(mat,i,j) && !flag[i][j])
			{
				ans[i][j]=1;
				flag[i][j]=1;
				continue;
			}
			for(i=0;i<r;i++)
				for(j=0;j<c;j++)
				{
					if(!flag[i][j])
					{
						//if both case fails,,,we add to the stack,,,
						temp=(struct node*)malloc(sizeof(struct node));
						temp->x=0;
						temp->y=0;
						temp->next=NULL;
						if(head==NULL) head=temp;
						for(tail=head;tail->next!=NULL;tail=tail->next);
						tail->next=temp;
						if(nextans(ans,i,j)==1)
							ans[i][j]=1;
						else{
						*/
	int n;
						for(i=0;i<r;i++)
							for(j=0;j<c;j++)
								if(!flag[i][j])
							{
									while((n=nextans(ans,i,j))!=0)
							{
										printf("i=%d j=%d",i,j);
								flag[i][j]=1;
								if(n==2) ans[i][j]+=2;
								if(n==1) ans[i][j]+=1;
							}
							}
	printf("\nFLAG\n");
						for(i=0;i<r;i++)
						{
							for(j=0;j<c;j++)
								printf("%d\t",flag[i][j]);
							printf("\n");
						}
						printf("\nANSWER,,,\n");
						for(i=0;i<r;i++)
						{
							for(j=0;j<c;j++)
								printf("%d\t",ans[i][j]);
							printf("\n");
						}
	return 0;
}

int main() 
{
	int t;
	scanf("%d",&t);
	while(t-->0)
	{
		bitmap();
		//scanf("%d %d",&r,&c);
		//int ans[r][c];
		
		
	}
	return 0;
}
/*
 ============================================================================
 Name        : Bitmap.c
 Author      : harini
 Version     :
 Copyright   : Your copyright notice
 Description : Hello World in C, Ansi-style
 ============================================================================
 */

#include <stdio.h>
#include <stdlib.h>

struct node
{
	int x;
	int y;
	struct node *next;
}*head=NULL,*temp,*tail,*cur;

int r,c,i,j,k;
int dirx[]={1,0,-1,0};
int diry[]={0,1,0,-1};

//fn checks whether the next no is 1,,,and that elt is 0,,,returns 1 if true,,,
/*int next(int **mat,int x1,int y1)
{
	int x2,y2;
	if(mat[i][j]==0)
	{
		for(k=0;k<6;k++)
		{
			x2=i+dirx[k];
			y2=j+diry[k];
			if(x2<0 || x2>r || y2<0 || y2>c) continue;
			if(mat[x2][y2]==0) return 1;
		}
	}
	return 0;
}*/

int nextans(int ans[1000][1000],int x1,int y1)
{
	int x2,y2;
	if(ans[x1][y1]==0)
	{
		for(k=0;k<6;k++)
		{
			x2=x1+dirx[k];
			y2=y1+diry[k];
			if(x2<0 || x2>r || y2<0 || y2>c) continue;
			if(ans[x2][y2]==-1) continue;
			if(ans[x2][y2]==1) return 2;
			if(ans[x2][y2]==0) return 1;
		}
	}
	return 0;
}

int bitmap()
{
	scanf("%d %d",&r,&c);
	int mat[r][c],ans[r][c],flag[r][c];
	char matc[r][c];
	for(i=0;i<r;i++)
		for(j=0;j<c;j++)
		{
			flag[i][j]=0;
			ans[i][j]=-1;
		}
	for(i=0;i<r;i++)
			scanf("%s",matc[i]);
	for(i=0;i<r;i++)
		for(j=0;j<c;j++)
		{
			mat[i][j]=matc[i][j]-48;
		}
/*	for(i=0;i<r;i++)
	{
		for(j=0;j<c;j++)
			printf("%d\t",mat[i][j]);
		printf("\n");
	}*/
	//case1:if the element if 1
	int x2,y2;
	//printf("i=%d j=%d\n",i,j);
	for(i=0;i<r;i++)
		for(j=0;j<c;j++)
		{
		//	printf("i=%d j=%d\n",i,j);
			if(mat[i][j]==1)// && !flag[i][j])
			{
				//printf("i=%d j=%d\n",i,j);
				flag[i][j]=1;
				ans[i][j]=0;
				//put all the adjacent elts to 1(int ans) if they are not 0(in mat)
				for(k=0;k<4;k++)
				{
					x2=i+dirx[k];
					y2=j+diry[k];
					if(x2<0 || y2<0 || x2>=r || y2>=c) continue;
					//printf("x2=%d y2=%d\n",x2,y2);
					if(mat[x2][y2]==1)
					{
						printf("x2=%d y2=%d mat val=1\n",x2,y2);
						ans[x2][y2]=0;
						flag[x2][y2]=1;
					}
					else
					{
						printf("x2=%d y2=%d mat val=0\n",x2,y2);
						ans[x2][y2]=1;
						flag[x2][y2]=1;
					}
				}
			}
		}
			//case2:element is 0,,,,and next element is one,,,
			/*if(next(mat,i,j) && !flag[i][j])
			{
				ans[i][j]=1;
				flag[i][j]=1;
				continue;
			}
			for(i=0;i<r;i++)
				for(j=0;j<c;j++)
				{
					if(!flag[i][j])
					{
						//if both case fails,,,we add to the stack,,,
						temp=(struct node*)malloc(sizeof(struct node));
						temp->x=0;
						temp->y=0;
						temp->next=NULL;
						if(head==NULL) head=temp;
						for(tail=head;tail->next!=NULL;tail=tail->next);
						tail->next=temp;
						if(nextans(ans,i,j)==1)
							ans[i][j]=1;
						else{
						*/
	int n;
						for(i=0;i<r;i++)
							for(j=0;j<c;j++)
								if(!flag[i][j])
							{
									while((n=nextans(ans,i,j))!=0)
							{
										printf("i=%d j=%d",i,j);
								flag[i][j]=1;
								if(n==2) ans[i][j]+=2;
								if(n==1) ans[i][j]+=1;
							}
							}
	printf("\nFLAG\n");
						for(i=0;i<r;i++)
						{
							for(j=0;j<c;j++)
								printf("%d\t",flag[i][j]);
							printf("\n");
						}
						printf("\nANSWER,,,\n");
						for(i=0;i<r;i++)
						{
							for(j=0;j<c;j++)
								printf("%d\t",ans[i][j]);
							printf("\n");
						}
	return 0;
}

int main() 
{
	int t;
	scanf("%d",&t);
	while(t-->0)
	{
		bitmap();
		//scanf("%d %d",&r,&c);
		//int ans[r][c];
		
		
	}
	return 0;
}

prog.cpp:199:8: error: redefinition of 'struct node'
struct node
^
prog.cpp:14:8: error: previous definition of 'struct node'
struct node
^
prog.cpp:204:3: error: conflicting declaration 'int* head'
}*head=NULL,*temp,*tail,*cur;
^
prog.cpp:19:3: note: previous declaration as 'node* head'
}*head=NULL,*temp,*tail,*cur;
^
prog.cpp:204:14: error: conflicting declaration 'int* temp'
}*head=NULL,*temp,*tail,*cur;
^
prog.cpp:19:14: note: previous declaration as 'node* temp'
}*head=NULL,*temp,*tail,*cur;
^
prog.cpp:204:20: error: conflicting declaration 'int* tail'
}*head=NULL,*temp,*tail,*cur;
^
prog.cpp:19:20: note: previous declaration as 'node* tail'
}*head=NULL,*temp,*tail,*cur;
^
prog.cpp:204:26: error: conflicting declaration 'int* cur'
}*head=NULL,*temp,*tail,*cur;
^
prog.cpp:19:26: note: previous declaration as 'node* cur'
}*head=NULL,*temp,*tail,*cur;
^
prog.cpp:206:5: error: redefinition of 'int r'
int r,c,i,j,k;
^
prog.cpp:21:5: note: 'int r' previously declared here
int r,c,i,j,k;
^
prog.cpp:206:7: error: redefinition of 'int c'
int r,c,i,j,k;
^
prog.cpp:21:7: note: 'int c' previously declared here
int r,c,i,j,k;
^
prog.cpp:206:9: error: redefinition of 'int i'
int r,c,i,j,k;
^
prog.cpp:21:9: note: 'int i' previously declared here
int r,c,i,j,k;
^
prog.cpp:206:11: error: redefinition of 'int j'
int r,c,i,j,k;
^
prog.cpp:21:11: note: 'int j' previously declared here
int r,c,i,j,k;
^
prog.cpp:206:13: error: redefinition of 'int k'
int r,c,i,j,k;
^
prog.cpp:21:13: note: 'int k' previously declared here
int r,c,i,j,k;
^
prog.cpp:207:10: error: redefinition of 'int dirx []'
int dirx[]={1,0,-1,0};
^
prog.cpp:22:5: note: 'int dirx [4]' previously defined here
int dirx[]={1,0,-1,0};
^
prog.cpp:208:10: error: redefinition of 'int diry []'
int diry[]={0,1,0,-1};
^
prog.cpp:23:5: note: 'int diry [4]' previously defined here
int diry[]={0,1,0,-1};
^
prog.cpp: In function 'int nextans(int (*)[1000], int, int)':
prog.cpp:227:5: error: redefinition of 'int nextans(int (*)[1000], int, int)'
int nextans(int ans[1000][1000],int x1,int y1)
^
prog.cpp:43:5: note: 'int nextans(int (*)[1000], int, int)' previously defined here
int nextans(int ans[1000][1000],int x1,int y1)
^
prog.cpp: In function 'int bitmap()':
prog.cpp:245:5: error: redefinition of 'int bitmap()'
int bitmap()
^
prog.cpp:61:5: note: 'int bitmap()' previously defined here
int bitmap()
^
prog.cpp:332:34: error: cannot convert 'int (*)[c]' to 'int (*)[1000]' for argument '1' to 'int nextans(int (*)[1000], int, int)'
while((n=nextans(ans,i,j))!=0)
^
prog.cpp: In function 'int main()':
prog.cpp:357:5: error: redefinition of 'int main()'
int main()
^
prog.cpp:172:5: note: 'int main()' previously defined here
int main()
^