#include <stdio.h>
#include <stdlib.h>
#define MAX 20
#define MAX_K 3
typedef struct Peca{
int top[ 3 ] ;
int bot[ 3 ] ;
int left[ 3 ] ;
int right[ 3 ] ;
int pos[ 2 ] ;
int up;
} Peca;
int recurcao( int score, int a, int x, int y) ;
int check( int aux, struct Peca * temp, int z) ;
struct Peca* rotate( struct Peca * temp) ;
struct Peca* createPeca( int a, int b, int c, int x, int y) ;
int npecas= 0 ;
struct Peca * pecas[ 20 ] ;
int input[ 20 ] [ 4 ] ;
int todas;
int tabuleiro[ 20 ] [ 20 ] ;
int main( void ) {
int a, b, c;
int res= 0 , restemp;
char buffer [ 10 ] ;
int cnt= 0 ;
//struct Peca * nova = rotate(createPeca(1,2,4,0,1));
//printf("%d,%d,%d,%d\n",nova->top[0],nova->right[0],nova->bot[0],nova->left[0]);
while ( fgets ( buffer
, sizeof ( buffer
) , stdin
) ) { if ( sscanf ( buffer
, "%d %d %d" ,& a
, & b
, & c
) == 3 ) { input[ cnt] [ 0 ] = a;
input[ cnt] [ 1 ] = b;
input[ cnt] [ 2 ] = c;
input[ cnt] [ 3 ] = 0 ;
cnt= cnt+ 1 ;
} else {
break ;
}
}
todas= cnt;
int i, j;
/*preenche tabuleiro*/
for ( i= 0 ; i< 20 ; i++ ) {
for ( j= 0 ; j< 20 ; j++ ) {
tabuleiro[ i] [ j] =- 1 ;
}
}
for ( i= 0 ; i< todas; i++ ) {
restemp = recurcao( 0 , i, 10 , 10 ) ;
//printf("%d\n",restemp);
if ( restemp> res) {
res= restemp;
}
}
return 0 ;
}
int recurcao( int score, int a, int x, int y) {
//printf("%d\n",score);
int i, j, k;
int aux;
int aux2, aux1, scoreTemp;
input[ a] [ 3 ] = 1 ;
struct Peca * nova = createPeca( input[ a] [ 0 ] , input[ a] [ 1 ] , input[ a] [ 2 ] , x, y) ;
printf ( "%d - %d %d,%d %d %d %d\n " , npecas
, nova
-> pos
[ 0 ] , nova
-> pos
[ 1 ] , nova
-> bot
[ 0 ] , nova
-> left
[ 0 ] , nova
-> top
[ 0 ] , nova
-> right
[ 0 ] ) ; aux= check( 0 , nova, 0 ) ;
printf ( "%d - %d %d,%d %d %d %d\n " , npecas
, nova
-> pos
[ 0 ] , nova
-> pos
[ 1 ] , nova
-> bot
[ 0 ] , nova
-> left
[ 0 ] , nova
-> top
[ 0 ] , nova
-> right
[ 0 ] ) ; if ( aux==- 1 ) {
return 0 ;
}
pecas[ npecas] = nova;
tabuleiro[ x] [ y] = npecas;
npecas++;
if ( npecas == todas) {
return score;
}
for ( i= 0 ; i< npecas; i++ ) {
if ( pecas[ i] -> up) {
if ( pecas[ i] -> bot[ 2 ] == 0 ) {
aux2 = pecas[ i] -> bot[ 0 ] ;
aux1 = pecas[ i] -> bot[ 1 ] ;
for ( k= 0 ; k< todas; k++ ) {
if ( input[ k] [ 3 ] == 0 ) {
if ( ( ( input[ k] [ 0 ] == aux1) && ( input[ k] [ 1 ] == aux2) )
|| ( ( input[ k] [ 1 ] == aux1) && ( input[ k] [ 2 ] == aux2) )
|| ( ( input[ k] [ 2 ] == aux1) && ( input[ k] [ 0 ] == aux2) ) ) {
scoreTemp = recurcao( score, k, pecas[ i] -> pos[ 0 ] - 1 , pecas[ i] -> pos[ 1 ] ) ;
if ( scoreTemp> score) {
score= scoreTemp;
}
}
}
}
}
if ( pecas[ i] -> left[ 2 ] == 0 ) {
aux2 = pecas[ i] -> left[ 0 ] ;
aux1 = pecas[ i] -> left[ 1 ] ;
for ( k= 0 ; k< todas; k++ ) {
if ( input[ k] [ 3 ] == 0 ) {
if ( ( ( input[ k] [ 0 ] == aux1) && ( input[ k] [ 1 ] == aux2) )
|| ( ( input[ k] [ 1 ] == aux1) && ( input[ k] [ 2 ] == aux2) )
|| ( ( input[ k] [ 2 ] == aux1) && ( input[ k] [ 0 ] == aux2) ) ) {
scoreTemp = recurcao( score, k, pecas[ i] -> pos[ 0 ] , pecas[ i] -> pos[ 1 ] - 1 ) ;
if ( scoreTemp> score) {
score= scoreTemp;
}
}
}
}
}
if ( pecas[ i] -> right[ 2 ] == 0 ) {
aux1 = pecas[ i] -> right[ 0 ] ;
aux2 = pecas[ i] -> right[ 1 ] ;
for ( k= 0 ; k< todas; k++ ) {
if ( input[ k] [ 3 ] == 0 ) {
if ( ( ( input[ k] [ 0 ] == aux1) && ( input[ k] [ 1 ] == aux2) ) ||
( ( input[ k] [ 1 ] == aux1) && ( input[ k] [ 2 ] == aux2) ) ||
( ( input[ k] [ 2 ] == aux1) && ( input[ k] [ 0 ] == aux2) ) ) {
scoreTemp = recurcao( score, k, pecas[ i] -> pos[ 0 ] , pecas[ i] -> pos[ 1 ] + 1 ) ;
if ( scoreTemp> score) {
score= scoreTemp;
}
}
}
}
}
}
else {
if ( pecas[ i] -> top[ 2 ] == 0 ) {
aux2 = pecas[ i] -> top[ 0 ] ;
aux1 = pecas[ i] -> top[ 1 ] ;
for ( k= 0 ; k< todas; k++ ) {
if ( input[ k] [ 3 ] == 0 ) {
if ( ( ( input[ k] [ 0 ] == aux1) && ( input[ k] [ 1 ] == aux2) )
|| ( ( input[ k] [ 1 ] == aux1) && ( input[ k] [ 2 ] == aux2) )
|| ( ( input[ k] [ 2 ] == aux1) && ( input[ k] [ 0 ] == aux2) ) ) {
scoreTemp = recurcao( score, k, pecas[ i] -> pos[ 0 ] + 1 , pecas[ i] -> pos[ 1 ] ) ;
if ( scoreTemp> score) {
score= scoreTemp;
}
}
}
}
}
if ( pecas[ i] -> right[ 2 ] == 0 ) {
aux2 = pecas[ i] -> right[ 0 ] ;
aux1 = pecas[ i] -> right[ 1 ] ;
for ( k= 0 ; k< todas; k++ ) {
if ( input[ k] [ 3 ] == 0 ) {
if ( ( ( input[ k] [ 0 ] == aux1) && ( input[ k] [ 1 ] == aux2) )
|| ( ( input[ k] [ 1 ] == aux1) && ( input[ k] [ 2 ] == aux2) )
|| ( ( input[ k] [ 2 ] == aux1) && ( input[ k] [ 0 ] == aux2) ) ) {
scoreTemp = recurcao( score, k, pecas[ i] -> pos[ 0 ] , pecas[ i] -> pos[ 1 ] + 1 ) ;
if ( scoreTemp> score) {
score= scoreTemp;
}
}
}
}
}
if ( pecas[ i] -> left[ 2 ] == 0 ) {
aux2 = pecas[ i] -> left[ 0 ] ;
aux1 = pecas[ i] -> left[ 1 ] ;
for ( k= 0 ; k< todas; k++ ) {
if ( input[ k] [ 3 ] == 0 ) {
if ( ( ( input[ k] [ 0 ] == aux1) && ( input[ k] [ 1 ] == aux2) )
|| ( ( input[ k] [ 1 ] == aux1) && ( input[ k] [ 2 ] == aux2) )
|| ( ( input[ k] [ 2 ] == aux1) && ( input[ k] [ 0 ] == aux2) ) ) {
scoreTemp = recurcao( score, k, pecas[ i] -> pos[ 0 ] , pecas[ i] -> pos[ 1 ] - 1 ) ;
if ( scoreTemp> score) {
score= scoreTemp;
}
}
}
}
}
}
}
input[ a] [ 3 ] = 0 ;
//free(pecas[npecas]);
npecas--;
tabuleiro[ x] [ y] =- 1 ;
/*DESOCUPAR FACES*/
if ( nova-> up) {
if ( tabuleiro[ x- 1 ] [ y] !=- 1 ) {
pecas[ tabuleiro[ x- 1 ] [ y] ] -> top[ 2 ] = 0 ;
}
if ( tabuleiro[ x] [ y+ 1 ] !=- 1 ) {
pecas[ tabuleiro[ x] [ y+ 1 ] ] -> left[ 2 ] = 0 ;
}
if ( tabuleiro[ x] [ y- 1 ] !=- 1 ) {
pecas[ tabuleiro[ x] [ y- 1 ] ] -> right[ 2 ] = 0 ;
}
} else {
if ( tabuleiro[ x+ 1 ] [ y] !=- 1 ) {
pecas[ tabuleiro[ x+ 1 ] [ y] ] -> bot[ 2 ] = 0 ;
}
if ( tabuleiro[ x] [ y+ 1 ] !=- 1 ) {
pecas[ tabuleiro[ x] [ y+ 1 ] ] -> left[ 2 ] = 0 ;
}
if ( tabuleiro[ x] [ y- 1 ] !=- 1 ) {
pecas[ tabuleiro[ x] [ y- 1 ] ] -> right[ 2 ] = 0 ;
}
}
for ( i= 0 ; i< npecas; i++ ) {
}
printf ( "score aux %d %d\n " , score
, aux
) ; score += aux;
return score;
}
int check( int aux, struct Peca * temp, int z) {
if ( z> 2 )
return - 1 ;
int x= temp-> pos[ 0 ] , y = temp-> pos[ 1 ] ;
if ( tabuleiro[ x] [ y] !=- 1 ) {
return- 1 ;
}
if ( temp-> up) {
if ( tabuleiro[ x- 1 ] [ y] !=- 1 ) {
if ( pecas[ tabuleiro[ x- 1 ] [ y] ] -> top[ 0 ] != temp-> bot[ 1 ] || pecas[ tabuleiro[ x- 1 ] [ y] ] -> top[ 1 ] != temp-> bot[ 0 ] ) {
* temp = * ( rotate( temp) ) ;
return check( aux, temp, z+ 1 ) ;
}
}
/*if(tabuleiro[x+1][y]!=-1){
if(pecas[tabuleiro[x+1][y]]->bot[0] != temp->top[0]){
temp = rotate(temp);
return check(aux,temp,z+1);
}
}*/
if ( tabuleiro[ x] [ y+ 1 ] !=- 1 ) {
if ( pecas[ tabuleiro[ x] [ y+ 1 ] ] -> left[ 0 ] != temp-> right[ 1 ] || pecas[ tabuleiro[ x] [ y+ 1 ] ] -> left[ 1 ] != temp-> right[ 0 ] ) {
* temp = * ( rotate( temp) ) ;
return check( aux, temp, z+ 1 ) ;
}
}
if ( tabuleiro[ x] [ y- 1 ] !=- 1 ) {
if ( pecas[ tabuleiro[ x] [ y- 1 ] ] -> right[ 0 ] != temp-> left[ 1 ] || pecas[ tabuleiro[ x] [ y- 1 ] ] -> right[ 1 ] != temp-> left[ 0 ] ) {
* temp = * ( rotate( temp) ) ;
return check( aux, temp, z+ 1 ) ;
}
}
} else {
/*if(tabuleiro[x-1][y]!=-1){
if(pecas[tabuleiro[x-1][y]]->top[0] != temp->bot[0]){
temp = rotate(temp);
return check(aux,temp,z+1);
}
}*/
if ( tabuleiro[ x+ 1 ] [ y] !=- 1 ) {
if ( pecas[ tabuleiro[ x+ 1 ] [ y] ] -> bot[ 0 ] != temp-> top[ 1 ] || pecas[ tabuleiro[ x+ 1 ] [ y] ] -> bot[ 1 ] != temp-> top[ 0 ] ) {
* temp = * ( rotate( temp) ) ;
return check( aux, temp, z+ 1 ) ;
}
}
if ( tabuleiro[ x] [ y+ 1 ] !=- 1 ) {
if ( pecas[ tabuleiro[ x] [ y+ 1 ] ] -> left[ 0 ] != temp-> right[ 1 ] || pecas[ tabuleiro[ x] [ y+ 1 ] ] -> left[ 1 ] != temp-> right[ 0 ] ) {
* temp = * ( rotate( temp) ) ;
return check( aux, temp, z+ 1 ) ;
}
}
if ( tabuleiro[ x] [ y- 1 ] !=- 1 ) {
if ( pecas[ tabuleiro[ x] [ y- 1 ] ] -> right[ 0 ] != temp-> left[ 1 ] || pecas[ tabuleiro[ x] [ y- 1 ] ] -> right[ 1 ] != temp-> left[ 0 ] ) {
* temp = * ( rotate( temp) ) ;
return check( aux, temp, z+ 1 ) ;
}
}
}
/*CALC SCORE + OCUPAR*/
if ( temp-> up) {
if ( tabuleiro[ x- 1 ] [ y] !=- 1 ) {
pecas[ tabuleiro[ x- 1 ] [ y] ] -> top[ 2 ] = 1 ;
temp-> bot[ 2 ] = 1 ;
aux+= temp-> bot[ 0 ] + temp-> bot[ 1 ] ;
}
if ( tabuleiro[ x] [ y+ 1 ] !=- 1 ) {
pecas[ tabuleiro[ x] [ y+ 1 ] ] -> left[ 2 ] = 1 ;
temp-> right[ 2 ] = 1 ;
aux+= temp-> right[ 0 ] + temp-> right[ 1 ] ;
}
if ( tabuleiro[ x] [ y- 1 ] !=- 1 ) {
pecas[ tabuleiro[ x] [ y- 1 ] ] -> right[ 2 ] = 1 ;
temp-> left[ 2 ] = 1 ;
aux+= temp-> left[ 0 ] + temp-> left[ 1 ] ;
}
} else {
if ( tabuleiro[ x+ 1 ] [ y] !=- 1 ) {
pecas[ tabuleiro[ x+ 1 ] [ y] ] -> bot[ 2 ] = 1 ;
temp-> top[ 2 ] = 1 ;
aux= temp-> top[ 0 ] + temp-> top[ 1 ] ;
}
if ( tabuleiro[ x] [ y+ 1 ] !=- 1 ) {
pecas[ tabuleiro[ x] [ y+ 1 ] ] -> left[ 2 ] = 1 ;
temp-> right[ 2 ] = 1 ;
aux+= temp-> right[ 0 ] + temp-> right[ 1 ] ;
}
if ( tabuleiro[ x] [ y- 1 ] !=- 1 ) {
pecas[ tabuleiro[ x] [ y- 1 ] ] -> right[ 2 ] = 1 ;
temp-> left[ 2 ] = 1 ;
aux+= temp-> left[ 0 ] + temp-> left[ 1 ] ;
}
}
return aux;
}
struct Peca * rotate( struct Peca * temp) {
int aux[ 3 ] ;
struct Peca * nova;
if ( temp-> up) {
aux[ 0 ] = temp-> left[ 0 ] ;
aux[ 1 ] = temp-> right[ 0 ] ;
aux[ 2 ] = temp-> bot[ 0 ] ;
nova = createPeca( aux[ 0 ] , aux[ 1 ] , aux[ 2 ] , temp-> pos[ 0 ] , temp-> pos[ 1 ] ) ;
} else {
aux[ 0 ] = temp-> top[ 0 ] ;
aux[ 1 ] = temp-> right[ 0 ] ;
aux[ 2 ] = temp-> left[ 0 ] ;
nova = createPeca( aux[ 0 ] , aux[ 1 ] , aux[ 2 ] , temp-> pos[ 0 ] , temp-> pos[ 1 ] ) ;
}
return nova;
}
struct Peca* createPeca( int a, int b, int c, int x, int y) {
struct Peca
* temp
= malloc ( sizeof ( struct Peca
) ) ; if ( ( x+ y) % 2 == 0 ) {
temp-> up = 1 ;
temp-> bot[ 0 ] = a;
temp-> bot[ 1 ] = b;
temp-> bot[ 2 ] = 0 ;
temp-> left[ 0 ] = b;
temp-> left[ 1 ] = c;
temp-> left[ 2 ] = 0 ;
temp-> right[ 0 ] = c;
temp-> right[ 1 ] = a;
temp-> right[ 2 ] = 0 ;
temp-> top[ 0 ] = c;
temp-> top[ 1 ] = c;
} else {
temp-> up = 0 ;
temp-> left[ 0 ] = a;
temp-> left[ 1 ] = b;
temp-> left[ 2 ] = 0 ;
temp-> top[ 0 ] = b;
temp-> top[ 1 ] = c;
temp-> top[ 2 ] = 0 ;
temp-> right[ 0 ] = c;
temp-> right[ 1 ] = a;
temp-> right[ 2 ] = 0 ;
temp-> bot[ 0 ] = a;
temp-> bot[ 1 ] = a;
}
temp-> pos[ 0 ] = x;
temp-> pos[ 1 ] = y;
return temp;
}
#include <stdio.h>
#include <stdlib.h>
#define MAX 20
#define MAX_K 3

typedef struct Peca{
 	int top[3];
 	int bot[3];
 	int left[3];
 	int right[3];
 	int pos[2];
	int up;
}Peca;

int recurcao(int score, int a, int x, int y);
int check(int aux, struct Peca *temp,int z);
struct Peca* rotate(struct Peca *temp);
struct Peca* createPeca( int a,int b,int c,int x,int y);

int npecas=0;
struct Peca *pecas[20];
int input[20][4];
int todas;
int tabuleiro[20][20];

int main(void) {
	int a, b, c;
	int res=0, restemp;
	char buffer [10];
	int cnt=0;
	//struct Peca * nova = rotate(createPeca(1,2,4,0,1));
	//printf("%d,%d,%d,%d\n",nova->top[0],nova->right[0],nova->bot[0],nova->left[0]);
	while(fgets (buffer,sizeof(buffer),stdin)){
		if (sscanf(buffer,"%d %d %d",&a, &b, &c)==3){
			input[cnt][0]=a;
			input[cnt][1]=b;
			input[cnt][2]=c;
			input[cnt][3]=0;
			cnt=cnt+1;
		}else{
			break;
		}
	}

	todas=cnt;
	int i,j;
	/*preenche tabuleiro*/
	for(i=0;i<20;i++){
		for(j=0;j<20;j++){
			tabuleiro[i][j]=-1;
		}
	}
	for(i=0;i<todas;i++){
		restemp = recurcao(0,i,10,10);
		//printf("%d\n",restemp);
		if (restemp>res){
			res=restemp;
		}

	}
	printf("%d\n",res);
	return 0;
}

int recurcao(int score, int a, int x, int y){

  //printf("%d\n",score);
	int i, j, k;
	int aux;
	int aux2, aux1, scoreTemp;
	input[a][3]=1;
	
	struct Peca *nova = createPeca(input[a][0],input[a][1],input[a][2],x,y);
	printf("%d - %d %d,%d %d %d %d\n",npecas,nova->pos[0],nova->pos[1],nova->bot[0],nova->left[0],nova->top[0],nova->right[0]);
	aux=check(0,nova,0);
	printf("%d\n",aux);
	printf("%d - %d %d,%d %d %d %d\n",npecas,nova->pos[0],nova->pos[1],nova->bot[0],nova->left[0],nova->top[0],nova->right[0]);
	if(aux==-1){
		return 0;
	}
	pecas[npecas] = nova;
	tabuleiro[x][y]=npecas;
	npecas++;
	if(npecas == todas){
		return score;
	}

	for(i=0;i<npecas;i++){
		if (pecas[i]->up){
			if (pecas[i]->bot[2]==0){
				aux2 = pecas[i]->bot[0];
				aux1 = pecas[i]->bot[1];
				for (k=0;k<todas;k++){
					if(input[k][3]==0){

						if(((input[k][0]==aux1) && (input[k][1]==aux2))
						|| ((input[k][1]==aux1) && (input[k][2]==aux2))
						|| ((input[k][2]==aux1) && (input[k][0]==aux2)) ){

							scoreTemp = recurcao(score,k,pecas[i]->pos[0]-1,pecas[i]->pos[1]);
							if(scoreTemp>score){
								score=scoreTemp;
							}
						}
					}
				}
			}
			if (pecas[i]->left[2]==0){
				aux2 = pecas[i]->left[0];
				aux1 = pecas[i]->left[1];
				for(k=0;k<todas;k++){
					if(input[k][3]==0){
						if(((input[k][0]==aux1) && (input[k][1]==aux2))
						||	((input[k][1]==aux1) && (input[k][2]==aux2))
						||	((input[k][2]==aux1) && (input[k][0]==aux2))){
							
							scoreTemp = recurcao(score,k,pecas[i]->pos[0],pecas[i]->pos[1]-1);
							if(scoreTemp>score){
								score=scoreTemp;
							}
						}
					}
				}
			}
			if(pecas[i]->right[2]==0){
				aux1 = pecas[i]->right[0];
				aux2 = pecas[i]->right[1];
				for(k=0;k<todas;k++){
					if(input[k][3]==0){
						if(((input[k][0]==aux1) && (input[k][1]==aux2)) ||
							((input[k][1]==aux1) && (input[k][2]==aux2)) ||
							((input[k][2]==aux1) && (input[k][0]==aux2))	){

							scoreTemp = recurcao(score,k,pecas[i]->pos[0],pecas[i]->pos[1]+1);
							if(scoreTemp>score){
								score=scoreTemp;
							}
						}
					}
				}
			}
		}
		else{
			if (pecas[i]->top[2]==0){
				aux2 = pecas[i]->top[0];
				aux1 = pecas[i]->top[1];
				for (k=0;k<todas;k++){
					if(input[k][3]==0){
						if(((input[k][0]==aux1) && (input[k][1]==aux2))
						|| ((input[k][1]==aux1) && (input[k][2]==aux2))
						|| ((input[k][2]==aux1) && (input[k][0]==aux2)) ){
							scoreTemp = recurcao(score,k,pecas[i]->pos[0]+1,pecas[i]->pos[1]);
							if(scoreTemp>score){
								score=scoreTemp;
							}
						}
					}
				}
			}
			if (pecas[i]->right[2]==0){
				aux2 = pecas[i]->right[0];
				aux1 = pecas[i]->right[1];
				for (k=0;k<todas;k++){
					if(input[k][3]==0){
						if(((input[k][0]==aux1) && (input[k][1]==aux2))
						|| ((input[k][1]==aux1) && (input[k][2]==aux2))
						|| ((input[k][2]==aux1) && (input[k][0]==aux2)) ){
							scoreTemp = recurcao(score,k,pecas[i]->pos[0],pecas[i]->pos[1]+1);
							if(scoreTemp>score){
								score=scoreTemp;
							}
						}
					}
				}
			}
			if (pecas[i]->left[2]==0){
				aux2 = pecas[i]->left[0];
				aux1 = pecas[i]->left[1];
				for (k=0;k<todas;k++){
					if(input[k][3]==0){
						if(((input[k][0]==aux1) && (input[k][1]==aux2))
						|| ((input[k][1]==aux1) && (input[k][2]==aux2))
						|| ((input[k][2]==aux1) && (input[k][0]==aux2)) ){
							scoreTemp = recurcao(score,k,pecas[i]->pos[0],pecas[i]->pos[1]-1);
							if(scoreTemp>score){
								score=scoreTemp;
							}
						}
					}
				}
			}
		}
	}
	input[a][3]=0;
	//free(pecas[npecas]);
	npecas--;
	tabuleiro[x][y]=-1;

	/*DESOCUPAR FACES*/
	if(nova->up){
		if(tabuleiro[x-1][y]!=-1){
			pecas[tabuleiro[x-1][y]]->top[2]=0;
		}
		if(tabuleiro[x][y+1]!=-1){
			pecas[tabuleiro[x][y+1]]->left[2]=0;
		}
		if(tabuleiro[x][y-1]!=-1){
			pecas[tabuleiro[x][y-1]]->right[2]=0;
		}
	}else{
		if(tabuleiro[x+1][y]!=-1){
			pecas[tabuleiro[x+1][y]]->bot[2]=0;
		}
		if(tabuleiro[x][y+1]!=-1){
			pecas[tabuleiro[x][y+1]]->left[2] =0;
		}
		if(tabuleiro[x][y-1]!=-1){
			pecas[tabuleiro[x][y-1]]->right[2] =0;
		}
	}
	for(i=0;i<npecas;i++){
		printf(" ");
	}
	printf("score aux %d %d\n",score,aux);
	score += aux;
	
	printf("%d\n",score);
	return score;
}

int check(int aux, struct Peca *temp,int z){
	
	if(z>2)
		return -1;
	int x=temp->pos[0],y =temp->pos[1];
	if(tabuleiro[x][y]!=-1){
		return-1;
	}
	if(temp->up){
		if(tabuleiro[x-1][y]!=-1){
			if(pecas[tabuleiro[x-1][y]]->top[0] != temp->bot[1] || pecas[tabuleiro[x-1][y]]->top[1] != temp->bot[0]){
				*temp = *(rotate(temp));
				
				return check(aux,temp,z+1);
			}
		}
		/*if(tabuleiro[x+1][y]!=-1){
			if(pecas[tabuleiro[x+1][y]]->bot[0] != temp->top[0]){
				temp = rotate(temp);
				return check(aux,temp,z+1);
			}
		}*/
		if(tabuleiro[x][y+1]!=-1){
			if(pecas[tabuleiro[x][y+1]]->left[0] != temp->right[1] || pecas[tabuleiro[x][y+1]]->left[1] != temp->right[0]){
				*temp = *(rotate(temp));
				return check(aux,temp,z+1);
			}
		}
		if(tabuleiro[x][y-1]!=-1){
			if(pecas[tabuleiro[x][y-1]]->right[0] != temp->left[1] || pecas[tabuleiro[x][y-1]]->right[1] != temp->left[0]){
				*temp = *(rotate(temp));
				return check(aux,temp,z+1);
			}
		}
	}else{
		/*if(tabuleiro[x-1][y]!=-1){
			if(pecas[tabuleiro[x-1][y]]->top[0] != temp->bot[0]){
				temp = rotate(temp);
				return check(aux,temp,z+1);
			}
		}*/
		if(tabuleiro[x+1][y]!=-1){
			if(pecas[tabuleiro[x+1][y]]->bot[0] != temp->top[1] || pecas[tabuleiro[x+1][y]]->bot[1] != temp->top[0]){
				*temp = *(rotate(temp));
				return check(aux,temp,z+1);
			}
		}
		if(tabuleiro[x][y+1]!=-1){
			if(pecas[tabuleiro[x][y+1]]->left[0] != temp->right[1] || pecas[tabuleiro[x][y+1]]->left[1] != temp->right[0]){
				*temp = *(rotate(temp));
				return check(aux,temp,z+1);
			}
		}
		if(tabuleiro[x][y-1]!=-1){
			if(pecas[tabuleiro[x][y-1]]->right[0] != temp->left[1] || pecas[tabuleiro[x][y-1]]->right[1] != temp->left[0]){
				*temp = *(rotate(temp));
				return check(aux,temp,z+1);
			}
		}
	}
	/*CALC SCORE + OCUPAR*/
	if(temp->up){
		if(tabuleiro[x-1][y]!=-1){
			pecas[tabuleiro[x-1][y]]->top[2]=1;
			temp->bot[2]=1;
			aux+=temp->bot[0]+temp->bot[1];
		}
		if(tabuleiro[x][y+1]!=-1){
			pecas[tabuleiro[x][y+1]]->left[2]=1;
			temp->right[2]=1;
			aux+=temp->right[0]+temp->right[1];
		}
		if(tabuleiro[x][y-1]!=-1){
			pecas[tabuleiro[x][y-1]]->right[2]=1;
			temp->left[2]=1;
			aux+=temp->left[0]+temp->left[1];
		}
	}else{
		if(tabuleiro[x+1][y]!=-1){
			pecas[tabuleiro[x+1][y]]->bot[2]=1;
			temp->top[2]=1;
			aux=temp->top[0]+temp->top[1];
		}
		if(tabuleiro[x][y+1]!=-1){
			pecas[tabuleiro[x][y+1]]->left[2] =1;
			temp->right[2]=1;
			aux+=temp->right[0]+temp->right[1];
		}
		if(tabuleiro[x][y-1]!=-1){
			pecas[tabuleiro[x][y-1]]->right[2] =1;
			temp->left[2] =1;
			aux+=temp->left[0]+temp->left[1];
		}
	}
	return aux;
}


struct Peca * rotate(struct Peca *temp){
	int aux[3];
	struct Peca *nova;
	if(temp->up){
		aux[0] = temp->left[0];
		aux[1] = temp->right[0];
		aux[2] = temp->bot[0];
		nova = createPeca(aux[0],aux[1],aux[2],temp->pos[0],temp->pos[1]);
	}else{
		aux[0] = temp->top[0];
		aux[1] = temp->right[0];
		aux[2] = temp->left[0];
		nova = createPeca(aux[0],aux[1],aux[2],temp->pos[0],temp->pos[1]);

	}
	return nova;
}


struct Peca* createPeca( int a,int b,int c,int x,int y){
	struct Peca* temp= malloc(sizeof(struct Peca));
	if((x+y)%2==0){
		temp->up = 1;
		temp->bot[0] = a;
		temp->bot[1] = b;
		temp->bot[2] = 0;
		temp->left[0] = b;
		temp->left[1] = c;
		temp->left[2] = 0;
		temp->right[0] = c;
		temp->right[1] = a;
		temp->right[2] =  0;
		temp->top[0] = c;
		temp->top[1] = c;
	}else{
		temp->up = 0;
		temp->left[0] = a;
		temp->left[1] = b;
		temp->left[2] = 0;
		temp->top[0] =  b;
		temp->top[1] =  c;
		temp->top[2] =  0;
		temp->right[0] = c;
		temp->right[1] = a;
		temp->right[2] =  0;
		temp->bot[0] = a;
		temp->bot[1] = a;
	}
	temp->pos[0] = x;
	temp->pos[1] = y;
	return temp;

}

stdout
0
0npecas colocadas: 1
teste
bot livre
left livre
right livre
npecas colocadas: 1
peca 0 - 5,5,2,3
2
7npecas colocadas: 2
teste
bot livre
left livre
right livre
npecas colocadas: 2
peca 0 - 5,5,2,3
peca 1 - 5,1,5,2
3
0npecas colocadas: 3
teste
bot livre
left livre
right livre
npecas colocadas: 3
peca 0 - 5,5,2,3
peca 1 - 5,1,5,2
peca 2 - 5,5,2,4
5
-1teste
teste2
top livre
npecas colocadas: 3
peca 0 - 5,5,2,3
peca 1 - 5,1,5,2
peca 2 - 5,5,2,4
4
10npecas colocadas: 4
teste
bot livre
left livre
right livre
teste
teste2
top livre
right livre
left livre
teste
bot livre
left livre
right livre
teste
bot livre
left livre
right livre
right livre
left livre
teste
bot livre
left livre
npecas colocadas: 3
peca 0 - 5,5,2,3
peca 1 - 5,1,0,2
peca 2 - 5,5,2,4
4
9npecas colocadas: 4
teste
bot livre
left livre
right livre
teste
teste2
top livre
right livre
left livre
teste
bot livre
left livre
right livre
npecas colocadas: 4
peca 0 - 5,5,2,3
peca 1 - 5,1,0,2
peca 2 - 5,1,2,4
peca 3 - 5,5,5,4
1
-1teste
teste2
top livre
right livre
left livre
right livre
teste
teste2
top livre
npecas colocadas: 2
peca 0 - 5,5,2,3
peca 1 - 5,1,0,2
4
10npecas colocadas: 3
teste
bot livre
left livre
right livre
npecas colocadas: 3
peca 0 - 5,5,2,3
peca 1 - 5,1,1,2
peca 2 - 5,5,4,5
3
0npecas colocadas: 4
teste
bot livre
left livre
right livre
teste
teste2
top livre
right livre
left livre
teste
bot livre
left livre
right livre
teste
bot livre
left livre
right livre
teste
teste2
top livre
right livre
left livre
npecas colocadas: 3
peca 0 - 5,5,2,3
peca 1 - 5,1,1,2
peca 2 - 5,5,4,5
3
-1teste
bot livre
left livre
right livre
right livre
left livre
1
0npecas colocadas: 1
teste
bot livre
left livre
npecas colocadas: 1
peca 0 - 5,5,1,2
0
7npecas colocadas: 2
teste
bot livre
left livre
npecas colocadas: 2
peca 0 - 5,1,1,2
peca 1 - 3,5,5,2
2
-1right livre
teste
teste2
top livre
right livre
left livre
right livre
stderr
*** Error in `./prog': double free or corruption (fasttop): 0x00002aeff82cb210 ***
======= Backtrace: =========
/lib/x86_64-linux-gnu/libc.so.6(+0x70bcb)[0x2aeff74e6bcb]
/lib/x86_64-linux-gnu/libc.so.6(+0x76f96)[0x2aeff74ecf96]
/lib/x86_64-linux-gnu/libc.so.6(+0x7778e)[0x2aeff74ed78e]
./prog(+0x15ef)[0x2aeff6b2d5ef]
./prog(+0x8a6)[0x2aeff6b2c8a6]
/lib/x86_64-linux-gnu/libc.so.6(__libc_start_main+0xf1)[0x2aeff74962b1]
./prog(+0x90a)[0x2aeff6b2c90a]
======= Memory map: ========
2aeff6b2c000-2aeff6b2e000 r-xp 00000000 fd:00 20772867 /home/gLrTBl/prog
2aeff6b2e000-2aeff6b32000 rw-p 00000000 00:00 0
2aeff6b3b000-2aeff6b3d000 rw-p 00000000 00:00 0
2aeff6d2d000-2aeff6d2e000 r--p 00001000 fd:00 20772867 /home/gLrTBl/prog
2aeff6d2e000-2aeff6d2f000 rw-p 00002000 fd:00 20772867 /home/gLrTBl/prog
2aeff6d2f000-2aeff6d52000 r-xp 00000000 fd:00 6073359 /lib/x86_64-linux-gnu/ld-2.24.so
2aeff6f52000-2aeff6f53000 r--p 00023000 fd:00 6073359 /lib/x86_64-linux-gnu/ld-2.24.so
2aeff6f53000-2aeff6f54000 rw-p 00024000 fd:00 6073359 /lib/x86_64-linux-gnu/ld-2.24.so
2aeff6f54000-2aeff6f55000 rw-p 00000000 00:00 0
2aeff6f55000-2aeff7058000 r-xp 00000000 fd:00 6073388 /lib/x86_64-linux-gnu/libm-2.24.so
2aeff7058000-2aeff7257000 ---p 00103000 fd:00 6073388 /lib/x86_64-linux-gnu/libm-2.24.so
2aeff7257000-2aeff7258000 r--p 00102000 fd:00 6073388 /lib/x86_64-linux-gnu/libm-2.24.so
2aeff7258000-2aeff7259000 rw-p 00103000 fd:00 6073388 /lib/x86_64-linux-gnu/libm-2.24.so
2aeff7259000-2aeff7271000 r-xp 00000000 fd:00 6073345 /lib/x86_64-linux-gnu/libpthread-2.24.so
2aeff7271000-2aeff7470000 ---p 00018000 fd:00 6073345 /lib/x86_64-linux-gnu/libpthread-2.24.so
2aeff7470000-2aeff7471000 r--p 00017000 fd:00 6073345 /lib/x86_64-linux-gnu/libpthread-2.24.so
2aeff7471000-2aeff7472000 rw-p 00018000 fd:00 6073345 /lib/x86_64-linux-gnu/libpthread-2.24.so
2aeff7472000-2aeff7476000 rw-p 00000000 00:00 0
2aeff7476000-2aeff760b000 r-xp 00000000 fd:00 6073482 /lib/x86_64-linux-gnu/libc-2.24.so
2aeff760b000-2aeff780a000 ---p 00195000 fd:00 6073482 /lib/x86_64-linux-gnu/libc-2.24.so
2aeff780a000-2aeff780e000 r--p 00194000 fd:00 6073482 /lib/x86_64-linux-gnu/libc-2.24.so
2aeff780e000-2aeff7810000 rw-p 00198000 fd:00 6073482 /lib/x86_64-linux-gnu/libc-2.24.so
2aeff7810000-2aeff7814000 rw-p 00000000 00:00 0
2aeff7814000-2aeff782a000 r-xp 00000000 fd:00 6073326 /lib/x86_64-linux-gnu/libgcc_s.so.1
2aeff782a000-2aeff7a29000 ---p 00016000 fd:00 6073326 /lib/x86_64-linux-gnu/libgcc_s.so.1
2aeff7a29000-2aeff7a2a000 r--p 00015000 fd:00 6073326 /lib/x86_64-linux-gnu/libgcc_s.so.1
2aeff7a2a000-2aeff7a2b000 rw-p 00016000 fd:00 6073326 /lib/x86_64-linux-gnu/libgcc_s.so.1
2aeff82c9000-2aeff82eb000 rw-p 00000000 00:00 0 [heap]
2aeffc000000-2aeffc021000 rw-p 00000000 00:00 0
2aeffc021000-2af000000000 ---p 00000000 00:00 0
7ffe65503000-7ffe65524000 rw-p 00000000 00:00 0 [stack]
7ffe65540000-7ffe65542000 r-xp 00000000 00:00 0 [vdso]
7ffe65542000-7ffe65544000 r--p 00000000 00:00 0 [vvar]
ffffffffff600000-ffffffffff601000 r-xp 00000000 00:00 0 [vsyscall]