//the latest
//the latest
/* package whatever; // don't place package name! */
import java.util.*;
import java.lang.*;
import java.io.*;
/* Name of the class has to be "Main" only if the class is public. */
class Idone
{
{
int[][][] Box = new int[9][9][11] ; for(int i= 0; i<9;i++) {
for(int j= 0;j<9;j++) {
for(int k = 0; k<9;k++) {
}//for k
}//for j
}//for i
/*assign( Box ,0 ,2 ,5 );
assign( Box , 0, 5,1 );
assign( Box , 0, 7,8);
assign( Box , 0, 8,6 );
assign( Box , 1, 3,2 );
assign( Box , 1,8 ,3 );
assign( Box , 2, 0,3 );
assign( Box , 2, 4,7 );
assign( Box , 3, 1,1 );
assign( Box , 3,3 ,4 );
assign( Box , 3,5 ,6 );
assign( Box , 3, 8, 7);
assign( Box , 4, 2,3 );
assign( Box , 4, 6,5 );
assign( Box , 5,0 ,7 );
assign( Box , 5,3 ,1 );
assign( Box , 5,5 ,3 );
assign( Box , 5, 7, 4);
assign( Box , 6,4 ,6 );
assign( Box , 6,8 ,9 );
assign( Box , 7,0 ,2 );
assign( Box , 7,5 ,7 );
assign( Box , 8,0 ,5 );
assign( Box , 8,1 ,8 );
assign( Box , 8, 3, 9);
assign( Box , 8, 6, 2);*/
/*assign( Box ,0 ,0 ,3 );
assign( Box , 0, 1,7 );
assign( Box , 0, 3,5);
assign( Box , 0, 4,1 );
assign( Box , 0, 5,8 );
assign( Box , 1,8 ,9 );
assign( Box , 2, 1,6 );
assign( Box , 2, 2,4 );
assign( Box , 2, 3,9 );
assign( Box , 2,6 ,8 );
assign( Box , 3,0 ,1 );
assign( Box , 3, 4, 5);
assign( Box , 3, 8,4 );
assign( Box , 4, 2,2 );
assign( Box , 4,6 ,7 );
assign( Box , 5,0 ,9 );
assign( Box , 5,4 ,3 );
assign( Box , 5, 8, 2);
assign( Box , 6,2 ,3 );
assign( Box , 6,5 ,7 );
assign( Box , 6,6 ,9 );
assign( Box , 6,7 ,5 );
assign( Box , 7,0 ,4 );
assign( Box , 8,3 ,8 );
assign( Box , 8, 4, 2);
assign( Box , 8, 5, 6);
assign( Box ,8,7,4);
assign( Box ,8,8,3);*/
/*
//Ozone
assign( Box ,0 ,1 ,7 );
assign( Box , 0, 3,9 );
assign( Box , 1, 2,3 );
assign( Box , 1, 4,4 );
assign( Box , 1, 8,7 );
assign( Box , 2,2 ,2 );
assign( Box , 2, 4,7 );
assign( Box , 2, 5,1 );
assign( Box , 2, 6,8 );
assign( Box , 2,7 ,6 );
assign( Box , 3,2 ,6 );
assign( Box , 3, 8, 4);
assign( Box , 4, 1,5 );
assign( Box , 4, 2,4 );
assign( Box , 4,4 ,8 );
assign( Box , 4,6 ,9 );
assign( Box , 4,7 ,3 );
assign( Box , 5, 0, 3);
assign( Box , 5,6 ,7 );
assign( Box , 6,1 ,3 );
assign( Box , 6,2 ,7 );
assign( Box , 6,3 ,6 );
assign( Box , 6,4 ,2 );
assign( Box , 6,6 ,1 );
assign( Box , 7, 0, 9);
assign( Box , 7, 4, 5);
assign( Box ,7,6,6);
assign( Box ,8,5,7);
assign( Box ,8,7,2);*/
/*assign( Box ,0 ,5 ,3 );
assign( Box , 0, 6,5 );
assign( Box , 0, 7,1 );
assign( Box , 0, 8,4 );
assign( Box , 1, 3,4 );
assign( Box , 1,8 ,8 );
assign( Box , 2, 3,6 );
assign( Box , 2, 4,7 );
assign( Box , 2, 8,2 );
assign( Box , 3,1 ,8 );
assign( Box , 3,2 ,1 );
assign( Box , 3, 8, 5);
assign( Box , 4, 2,3 );
assign( Box , 4, 6,2 );
assign( Box , 5,0 ,2 );
assign( Box , 5,6 ,9 );
assign( Box , 5,7 ,6 );
assign( Box , 6, 0, 5);
assign( Box , 6,4 ,1 );
assign( Box , 6,5 ,9 );
assign( Box , 7,0 ,9 );
assign( Box , 7,5 ,7 );
assign( Box , 8,0 ,1 );
assign( Box , 8,1 ,7 );
assign( Box , 8, 2, 6);
assign( Box , 8, 3, 5);*/
/*assign( Box ,0 ,2,6 );
assign( Box , 0,4 ,1 );
assign( Box , 0,6 ,8 );
assign( Box , 0,8 ,3 );
assign( Box , 1,1 ,7 );
assign( Box , 1,4 ,2 );
assign( Box , 2,0 ,8 );
assign( Box , 2,5 ,4 );
assign( Box , 2,8 ,5 );
assign( Box , 3,3 ,5 );
assign( Box , 3,6 ,4 );
assign( Box , 4,0 ,5 );
assign( Box , 4,1 ,4 );
assign( Box , 4,7 ,3 );
assign( Box ,4 ,8 ,2 );
assign( Box , 5,2 ,7 );
assign( Box , 5,5 ,8 );
assign( Box , 6,0 ,6 );
assign( Box , 6,3 ,7 );
assign( Box , 6, 8,1 );
assign( Box , 7, 4,8 );
assign( Box , 7, 7,9 );
assign( Box , 8, 0,2 );
assign( Box , 8, 2, 4);
assign( Box , 8, 4,5 );
assign( Box ,8 , 6,6 );*/
/*assign(Box,0,1,1);
assign(Box,0,2,8);
assign(Box,0,5,4);
assign(Box,0,6,3);
assign(Box,1,0,3);
assign(Box,1,5,5);
assign(Box,1,6,4);
assign(Box,2,0,7);
assign(Box,2,4,2);
assign(Box,2,7,8);
assign(Box,2,8,1);
assign(Box,3,7,5);
assign(Box,3,8,4);
assign(Box,4,2,4);
assign(Box,4,6,9);
assign(Box,5,0,8);
assign(Box,5,1,5);
assign(Box,6,0,2);
assign(Box,6,1,7);
assign(Box,6,4,9);
assign(Box,6,8,3);
assign(Box,7,2,1);
assign(Box,7,3,8);
assign(Box,7,8,7);
assign(Box,8,2,9);
assign(Box,8,3,7);
assign(Box,8,6,5);
assign(Box,8,7,1);
*/
for (int i = 0 ; i < 10; i++){
}
//is_solved(Box);
System.
out.
println("_______________"); for (int i = 0 ; i <9; i++){
print_possibilities_of_specific_value
(Box,
7);//print_possibilities_of_specific_square(Box,0,0);
print_possibilities_of_each_square
(Box);}
/////is_unique(Box);
//System.out.println("_______________");
//print_big_box(Box);
}
public static void print_possibilities_of_each_square(int[][][] B_Box){
// print the possibility of a certain square
// System.out.println(check_same_big_box(B_Box,1,5,1));
for(int i = 0; i<9 ; i++){
if (i%3==0){
System.
out.
println("____________________"); }
for(int j = 0;j<9 ; j++){
if (j%3==0){
}
System.
out.
print(B_Box
[i
][j
][10]+ " "); }
}
}
public static void print_possibilities_of_specific_value(int[][][] B_Box, int v ){
// print the possibility of a certain square
// System.out.println(check_same_big_box(B_Box,1,5,1));
for(int i = 0; i<9 ; i++){
if (i%3==0){
System.
out.
println("____________________"); }
for(int j = 0;j<9 ; j++){
if (j%3==0){
}
System.
out.
print(B_Box
[i
][j
][v
-1]+ " "); }
}
}
public static void print_possibilities_of_specific_square(int[][][] B_Box, int r, int c){
// print the possibility of a certain square
for(int i = 0; i<9 ; i++){
System.
out.
print(B_Box
[r
][c
][i
]+ " ");
}
}
public static void print_big_box(int[][][] B_Box){
for(int i = 0; i<9 ; i++){
for(int j = 0; j<9 ; j++){
System.
out.
print(B_Box
[i
][j
][9] + " "); }//for j
}//for i
}//print_big_box()
public static void change_marks_same_big_box(int[][][] B_Box, int r,int c, int val) {
for(int i = r - r%3; i<3+(r - r%3) ; i++){
for(int j = c - c%3; j<3+(c - c%3) ; j++){
if ( (B_Box[i][j][9] == 0) && ( B_Box[i][j][10]>1) && (B_Box[i][j][val-1]==1)){
B_Box[i][j][val-1]=0;
B_Box[i][j][10]--;
/* if( B_Box[i][j][10]==1){
for (int a = 0 ; a < 9 ; a++) {
if ( B_Box[i][j][a]==1) {
assign(B_Box,i,j,a+1);
}//if
}//for a
}*///if
//check_small_square_in_big_square(BBBox,b_b,i);
}//if
}//for j
}//for i
}//change_marks_same_big_box
public static void change_marks_same_row(int[][][] B_Box, int r,int c, int val) {
for(int j = 0; j<9 ; j++){
if ( (B_Box[r][j][9] == 0) && ( B_Box[r][j][10]>1)&& (B_Box[r][j][val-1]==1)){
B_Box[r][j][val-1]=0;
B_Box[r][j][10]--;
/* if( B_Box[r][j][10]==1){
for (int a = 0 ; a < 9 ; a++) {
if ( B_Box[r][j][a]==1) {
assign(B_Box,r,j,a+1);
}//if
}//for a
}*///if
//check_small_square_in_big_square(BBBox,b_b,i);
}//if
}//for j
}//change_marks_same_row
public static void change_marks_same_column(int[][][] B_Box, int r,int c, int val) {
for(int i = 0; i<9 ; i++){
if ( (B_Box[i][c][9] == 0) && ( B_Box[i][c][10]>1)&& (B_Box[i][c][val-1]==1)){
B_Box[i][c][val-1]=0;
B_Box[i][c][10]--;
/* if( B_Box[i][c][10]==1){
for (int a = 0 ; a < 9 ; a++) {
if ( B_Box[i][c][a]==1) {
assign(B_Box,i,c,a+1);
}//if
}//for a
}*/
//if
//check_small_square_in_big_square(BBBox,b_b,i);
}//if
}//for j
}//change_marks_same_column
public static int check_same_big_box(int[][][] B_Box, int r,int c, int val) {
int cnts=0;
int cntr=0;
int cntc=0;
int cnt=0;
int x=-1;
int y=-1;
int u=-1;
int v=-1;
for(int i = r - r%3; i<3+(r - r%3) ; i++){
for(int j = c - c%3; j<3+(c - c%3) ; j++){
if ( (B_Box[i][j][9] == 0) &&(B_Box[i][j][val-1]==1)&&(B_Box[r][c][val-1]==1)){
cnts++;
// if((i==0)&&(j==3) &&(val==3))
// {System.out.println("hiiiii cnts: " + cnts + "r: "+i +"col: "+j );
// }
if(cnts==1){
x=i;
y=j;
}
if(cnts==2){
u=i;
v=j;
}
}//if
}//for j
}//for i
if(cnts>0){
for(int i = 0; i<9;i++){
if ( (B_Box[i][c][9] == 0) &&(B_Box[i][c][val-1]==1)&&(B_Box[r][c][val-1]==1)){
cntc++;
}//if
}//for i
if (cntc>0){
for(int j = 0;j<9;j++){
if ( (B_Box[r][j][9] == 0) &&(B_Box[r][j][val-1]==1)&&(B_Box[r][c][val-1]==1)){
cntr++;
}//if
}//for i
}//if cntc
}//if
if(cnts==2){
//System.out.println("hiiiiiiiiiiiii");
if(y==v){
for(int i=0;i<9;i++){
if((i!=x)&&(i!=u)&&(B_Box[i][y][val-1]==1)){
// if((i==0)&&(y==3) &&(val==3))
// {System.out.println("hiiiiiMarcel" + cnts);
// }
B_Box[i][y][val-1]=0;
B_Box[i][y][10]--;
}
}
}
if(x==u){
for(int i=0;i<9;i++){
if((i!=y)&&(i!=v)&&(B_Box[x][i][val-1]==1)){
B_Box[x][i][val-1]=0;
B_Box[x][i][10]--;
}
}
}
}
// if((r==0)&&(c==3) &&(val==3))
//// {
//System.out.println("cnts: "+ cnts + " cntc: "+ cntc+" cntr: "+ cntr);
//}
if ((cnts==1)||(cntc==1)||(cntr==1)){
cnt=1;
}
return cnt;
}//check_same_big_box
public static void is_unique(int[][][] B_Box) {
for(int m = 0; m<9 ; m++){
for(int n = 0; n<9 ; n++){
// if((m==0)&&(n==3)){
// System.out.println("check_same_big_box("+m+","+n+","+6+")" +B_Box[m][n][10]+" "+B_Box[m][n][9] + " "+check_same_big_box(B_Box,m,n,3));
// }//if
if((B_Box[m][n][9] == 0) && ( B_Box[m][n][10]>1)){
for (int a = 1 ; a < 10 ; a++) {
if(check_same_big_box(B_Box,m,n,a)==1){
assign(B_Box,m,n,a);
}//if
}//for a
}//if
if((B_Box[m][n][9] == 0) && ( B_Box[m][n][10]==1)){
for (int a = 1 ; a < 10 ; a++) {
if(B_Box[m][n][a-1]==1){
assign(B_Box,m,n,a);
}//if
}//for a
}//if
}//for j
}//for //i
}
public static void is_solved(int[][][] B_Box) {
for(int i = 0; i<9 ; i++){
for(int j = 0; j<9 ; j++){
if((B_Box[i][j][9] == 0) && ( B_Box[i][j][10]==1)){
for (int a = 0 ; a < 9 ; a++) {
if ( B_Box[i][j][a]==1) {
assign(B_Box,i,j,a+1);
}//if
}//fora
}//if
}//forj
}//for i
}
public static void assign(int[][][] B_Box, int r,int c, int val) {
B_Box[r][c][9]= val;
B_Box[r][c][10]=1;
B_Box[r][c][val-1]=1;
for (int i = 0; i < 9; i++){
if(i!=(val-1)){
B_Box[r][c][i]=0;
}//if
}//for i
change_marks_same_big_box(B_Box,r,c,val);
change_marks_same_row(B_Box,r,c,val);
change_marks_same_column(B_Box,r,c,val);
is_unique(B_Box);
//is_solved(BBBox);
}
}
//the latest
//the latest
/* package whatever; // don't place package name! */
import java.util.*;
import java.lang.*;
import java.io.*;



/* Name of the class has to be "Main" only if the class is public. */
 class Idone
{
public static void main (String[] args) throws java.lang.Exception
{
int[][][]  Box = new int[9][9][11] ;
for(int i= 0; i<9;i++) {
for(int j= 0;j<9;j++) {
Box[i][j][9]=0;
Box[i][j][10]=9;
for(int k = 0; k<9;k++) {
Box[i][j][k] = 1;
}//for k
}//for j
}//for i
/*assign( Box ,0 ,2 ,5 );
assign( Box , 0, 5,1 );
assign( Box , 0, 7,8);
assign( Box , 0, 8,6 );
assign( Box , 1, 3,2 );
assign( Box , 1,8 ,3 );
assign( Box , 2, 0,3 );
assign( Box , 2, 4,7 );
assign( Box , 3, 1,1 );
assign( Box , 3,3 ,4 );
assign( Box , 3,5 ,6 );
assign( Box , 3, 8, 7);
assign( Box , 4, 2,3 );
assign( Box , 4, 6,5 );
assign( Box , 5,0 ,7 );
assign( Box , 5,3 ,1 );
assign( Box , 5,5 ,3 );
assign( Box , 5, 7, 4);
assign( Box , 6,4 ,6 );
assign( Box , 6,8 ,9 );
assign( Box , 7,0 ,2 );
assign( Box , 7,5 ,7 );
assign( Box , 8,0 ,5 );
assign( Box , 8,1 ,8 );
assign( Box , 8, 3, 9);
assign( Box , 8, 6, 2);*/

/*assign( Box ,0 ,0 ,3 );
assign( Box , 0, 1,7 );
assign( Box , 0, 3,5);
assign( Box , 0, 4,1 );
assign( Box , 0, 5,8 );
assign( Box , 1,8 ,9 );
assign( Box , 2, 1,6 );
assign( Box , 2, 2,4 );
assign( Box , 2, 3,9 );
assign( Box , 2,6 ,8 );
assign( Box , 3,0 ,1 );
assign( Box , 3, 4, 5);
assign( Box , 3, 8,4 );
assign( Box , 4, 2,2 );
assign( Box , 4,6 ,7 );
assign( Box , 5,0 ,9 );
assign( Box , 5,4 ,3 );
assign( Box , 5, 8, 2);
assign( Box , 6,2 ,3 );
assign( Box , 6,5 ,7 );
assign( Box , 6,6 ,9 );
assign( Box , 6,7 ,5 );
assign( Box , 7,0 ,4 );
assign( Box , 8,3 ,8 );
assign( Box , 8, 4, 2);
assign( Box , 8, 5, 6);
assign( Box ,8,7,4);
assign( Box ,8,8,3);*/
/*
//Ozone
assign( Box ,0 ,1 ,7 );
assign( Box , 0, 3,9 );
assign( Box , 1, 2,3 );
assign( Box , 1, 4,4 );
assign( Box , 1, 8,7 );
assign( Box , 2,2 ,2 );
assign( Box , 2, 4,7 );
assign( Box , 2, 5,1 );
assign( Box , 2, 6,8 );
assign( Box , 2,7 ,6 );
assign( Box , 3,2 ,6 );
assign( Box , 3, 8, 4);
assign( Box , 4, 1,5 );
assign( Box , 4, 2,4 );
assign( Box , 4,4 ,8 );
assign( Box , 4,6 ,9 );
assign( Box , 4,7 ,3 );
assign( Box , 5, 0, 3);
assign( Box , 5,6 ,7 );
assign( Box , 6,1 ,3 );
assign( Box , 6,2 ,7 );
assign( Box , 6,3 ,6 );
assign( Box , 6,4 ,2 );
assign( Box , 6,6 ,1 );
assign( Box , 7, 0, 9);
assign( Box , 7, 4, 5);
assign( Box ,7,6,6);
assign( Box ,8,5,7);
assign( Box ,8,7,2);*/

/*assign( Box ,0 ,5 ,3 );
assign( Box , 0, 6,5 );
assign( Box , 0, 7,1 );
assign( Box , 0, 8,4 );
assign( Box , 1, 3,4 );
assign( Box , 1,8 ,8 );
assign( Box , 2, 3,6 );
assign( Box , 2, 4,7 );
assign( Box , 2, 8,2 );
assign( Box , 3,1 ,8 );
assign( Box , 3,2 ,1 );
assign( Box , 3, 8, 5);
assign( Box , 4, 2,3 );
assign( Box , 4, 6,2 );
assign( Box , 5,0 ,2 );
assign( Box , 5,6 ,9 );
assign( Box , 5,7 ,6 );
assign( Box , 6, 0, 5);
assign( Box , 6,4 ,1 );
assign( Box , 6,5 ,9 );
assign( Box , 7,0 ,9 );
assign( Box , 7,5 ,7 );
assign( Box , 8,0 ,1 );
assign( Box , 8,1 ,7 );
assign( Box , 8, 2, 6);
assign( Box , 8, 3, 5);*/

/*assign( Box ,0 ,2,6 );
assign( Box , 0,4 ,1 );
assign( Box , 0,6 ,8 );
assign( Box , 0,8 ,3 );
assign( Box , 1,1 ,7 );
assign( Box , 1,4 ,2 );
assign( Box , 2,0 ,8 );
assign( Box , 2,5 ,4 );
assign( Box , 2,8 ,5 );
assign( Box , 3,3 ,5 );
assign( Box , 3,6 ,4 );
assign( Box , 4,0 ,5 );
assign( Box , 4,1 ,4 );
assign( Box , 4,7 ,3 );
assign( Box ,4 ,8 ,2 );
assign( Box , 5,2 ,7 );
assign( Box , 5,5 ,8 );
assign( Box , 6,0 ,6 );
assign( Box , 6,3 ,7 );
assign( Box , 6, 8,1 );
assign( Box , 7, 4,8 );
assign( Box , 7, 7,9 );
assign( Box , 8, 0,2 );
assign( Box , 8, 2, 4);
assign( Box , 8, 4,5 );
assign( Box ,8 , 6,6 );*/

assign(Box,0,3,4);
assign(Box,0,4,8);
assign(Box,0,6,6);
assign(Box,0,7,2);
assign(Box,1,4,2);
assign(Box,1,8,9);
assign(Box,2,2,3);
assign(Box,2,5,7);
assign(Box,2,8,5);
assign(Box,3,0,9);
assign(Box,3,5,8);
assign(Box,3,6,5);
assign(Box,4,8,7);
assign(Box,4,0,1);
assign(Box,4,1,4);
assign(Box,4,7,8);
assign(Box,5,2,7);
assign(Box,5,3,2);
assign(Box,5,8,1);
assign(Box,6,0,2);
assign(Box,6,3,8);
assign(Box,6,6,3);
assign(Box,7,0,4);
assign(Box,7,4,6);
assign(Box,8,1,9);
assign(Box,8,2,8);
assign(Box,8,4,5);
assign(Box,8,5,4);

/*assign(Box,0,1,1);
assign(Box,0,2,8);
assign(Box,0,5,4);
assign(Box,0,6,3);
assign(Box,1,0,3);
assign(Box,1,5,5);
assign(Box,1,6,4);
assign(Box,2,0,7);
assign(Box,2,4,2);
assign(Box,2,7,8);
assign(Box,2,8,1);
assign(Box,3,7,5);
assign(Box,3,8,4);
assign(Box,4,2,4);
assign(Box,4,6,9);
assign(Box,5,0,8);
assign(Box,5,1,5);
assign(Box,6,0,2);
assign(Box,6,1,7);
assign(Box,6,4,9);
assign(Box,6,8,3);
assign(Box,7,2,1);
assign(Box,7,3,8);
assign(Box,7,8,7);
assign(Box,8,2,9);
assign(Box,8,3,7);
assign(Box,8,6,5);
assign(Box,8,7,1);
*/
for (int i = 0 ; i < 10; i++){
is_unique(Box);
}
print_big_box(Box);
//is_solved(Box);
System.out.println("_______________");
for (int i = 0 ; i <9; i++){
print_possibilities_of_specific_value(Box,7);
//print_possibilities_of_specific_square(Box,0,0);
print_possibilities_of_each_square(Box);
}
/////is_unique(Box);
//System.out.println("_______________");
//print_big_box(Box);
}
public static void print_possibilities_of_each_square(int[][][] B_Box){
	// print the possibility of a certain square
	//	System.out.println(check_same_big_box(B_Box,1,5,1));

for(int i = 0; i<9 ; i++){
		if (i%3==0){
			System.out.println("____________________");
	}
	for(int j = 0;j<9 ; j++){
	if (j%3==0){
			System.out.print("|");
	}
	System.out.print(B_Box[i][j][10]+ " ");
	}
	System.out.println();

	
}
System.out.println();
}
public static void print_possibilities_of_specific_value(int[][][] B_Box, int v ){
	// print the possibility of a certain square
	//	System.out.println(check_same_big_box(B_Box,1,5,1));

for(int i = 0; i<9 ; i++){
		if (i%3==0){
			System.out.println("____________________");
	}
	for(int j = 0;j<9 ; j++){
	if (j%3==0){
			System.out.print("|");
	}
	System.out.print(B_Box[i][j][v-1]+ " ");
	}
	System.out.println();

	
}
System.out.println();
}
public static void print_possibilities_of_specific_square(int[][][] B_Box, int r, int c){
	// print the possibility of a certain square

for(int i = 0; i<9 ; i++){
	System.out.print(B_Box[r][c][i]+ " ");
	
}
System.out.println();
}
public static void print_big_box(int[][][]  B_Box){

for(int i = 0; i<9 ; i++){
for(int j = 0; j<9 ; j++){
System.out.print(B_Box[i][j][9] + " ");
}//for j

System.out.println();
}//for i
}//print_big_box()

public static void change_marks_same_big_box(int[][][]  B_Box, int r,int c, int val) {
	
for(int i = r - r%3; i<3+(r - r%3) ; i++){
for(int j = c - c%3; j<3+(c - c%3) ; j++){

if ( (B_Box[i][j][9] == 0) && ( B_Box[i][j][10]>1) && (B_Box[i][j][val-1]==1)){
	B_Box[i][j][val-1]=0;
	B_Box[i][j][10]--;
/*	if( B_Box[i][j][10]==1){
		for (int a = 0 ; a < 9 ; a++)	{
		if ( B_Box[i][j][a]==1)	{
	
		assign(B_Box,i,j,a+1);
	}//if
	}//for a
	}*///if
	//check_small_square_in_big_square(BBBox,b_b,i);

}//if
}//for j
}//for i	
}//change_marks_same_big_box

public static void change_marks_same_row(int[][][]  B_Box, int r,int c, int val) {
	

for(int j = 0; j<9 ; j++){

if ( (B_Box[r][j][9] == 0) && ( B_Box[r][j][10]>1)&& (B_Box[r][j][val-1]==1)){
	B_Box[r][j][val-1]=0;
	B_Box[r][j][10]--;
/*	if( B_Box[r][j][10]==1){
		for (int a = 0 ; a < 9 ; a++)	{
		if ( B_Box[r][j][a]==1)	{
	
		assign(B_Box,r,j,a+1);
	}//if
	}//for a
	}*///if
	//check_small_square_in_big_square(BBBox,b_b,i);

}//if
}//for j
	
}//change_marks_same_row

public static void change_marks_same_column(int[][][]  B_Box, int r,int c, int val) {
	

for(int i = 0; i<9 ; i++){

if ( (B_Box[i][c][9] == 0) && ( B_Box[i][c][10]>1)&& (B_Box[i][c][val-1]==1)){
	B_Box[i][c][val-1]=0;
	B_Box[i][c][10]--;
/*	if( B_Box[i][c][10]==1){
	for (int a = 0 ; a < 9 ; a++)	{
	if ( B_Box[i][c][a]==1)	{

	 assign(B_Box,i,c,a+1);
	}//if
	}//for a
	}*/
	//if
	//check_small_square_in_big_square(BBBox,b_b,i);

}//if
}//for j
	
}//change_marks_same_column

public static int check_same_big_box(int[][][]  B_Box, int r,int c, int val) {
int cnts=0;
int cntr=0;
int cntc=0;
int cnt=0;
int x=-1;
int y=-1;
int u=-1;
int v=-1;

for(int i = r - r%3; i<3+(r - r%3) ; i++){
for(int j = c - c%3; j<3+(c - c%3) ; j++){

if ( (B_Box[i][j][9] == 0) &&(B_Box[i][j][val-1]==1)&&(B_Box[r][c][val-1]==1)){
	cnts++;
//	if((i==0)&&(j==3) &&(val==3))
//	{System.out.println("hiiiii  cnts:  " + cnts + "r: "+i +"col: "+j  );
//	}
	if(cnts==1){
		x=i;
		y=j;
	}
	if(cnts==2){
		u=i;
		v=j;
	}
	
}//if

}//for j
}//for i
if(cnts>0){
for(int i = 0; i<9;i++){
if ( (B_Box[i][c][9] == 0) &&(B_Box[i][c][val-1]==1)&&(B_Box[r][c][val-1]==1)){
	cntc++;
	
}//if	
}//for i

if (cntc>0){
	for(int j = 0;j<9;j++){
if ( (B_Box[r][j][9] == 0) &&(B_Box[r][j][val-1]==1)&&(B_Box[r][c][val-1]==1)){
	cntr++;
	
}//if	
}//for i
}//if cntc

}//if
if(cnts==2){
	//System.out.println("hiiiiiiiiiiiii");
	if(y==v){
		for(int i=0;i<9;i++){
			if((i!=x)&&(i!=u)&&(B_Box[i][y][val-1]==1)){
				//	if((i==0)&&(y==3) &&(val==3))
//	{System.out.println("hiiiiiMarcel" + cnts);
//	}
			B_Box[i][y][val-1]=0;
			B_Box[i][y][10]--;
			}
		}
	}
	if(x==u){
		for(int i=0;i<9;i++){
			if((i!=y)&&(i!=v)&&(B_Box[x][i][val-1]==1)){
			B_Box[x][i][val-1]=0;
			B_Box[x][i][10]--;
			}
		}
	}	
}
//	if((r==0)&&(c==3) &&(val==3))
////	{
//System.out.println("cnts: "+ cnts + " cntc: "+ cntc+" cntr: "+ cntr);
//}
if ((cnts==1)||(cntc==1)||(cntr==1)){
	cnt=1;
}
return cnt;
}//check_same_big_box

public static void is_unique(int[][][]  B_Box) {

for(int m = 0; m<9 ; m++){
	for(int n = 0; n<9 ; n++){
		//	if((m==0)&&(n==3)){
	//	System.out.println("check_same_big_box("+m+","+n+","+6+")" +B_Box[m][n][10]+"   "+B_Box[m][n][9] + "  "+check_same_big_box(B_Box,m,n,3));	
		//	}//if
	
	if((B_Box[m][n][9] == 0) && ( B_Box[m][n][10]>1)){
		for (int a = 1 ; a < 10 ; a++)	{
			if(check_same_big_box(B_Box,m,n,a)==1){
		
				assign(B_Box,m,n,a);
		
			
			}//if
			}//for a

		}//if
			if((B_Box[m][n][9] == 0) && ( B_Box[m][n][10]==1)){
		for (int a = 1 ; a < 10 ; a++)	{
			if(B_Box[m][n][a-1]==1){
		
				assign(B_Box,m,n,a);
		
			
			}//if
			}//for a

		}//if
	}//for j
	}//for //i
			
}

public static void is_solved(int[][][]  B_Box) {

for(int i = 0; i<9 ; i++){
	for(int j = 0; j<9 ; j++){
	
	if((B_Box[i][j][9] == 0) && ( B_Box[i][j][10]==1)){
		for (int a = 0 ; a < 9 ; a++)	{
		if ( B_Box[i][j][a]==1)	{
	
		assign(B_Box,i,j,a+1);
	}//if
		}//fora
		}//if 
		}//forj
}//for i

} 


public static void assign(int[][][]  B_Box, int r,int c, int val) {

B_Box[r][c][9]= val;
B_Box[r][c][10]=1;
B_Box[r][c][val-1]=1;
for (int i = 0; i < 9; i++){
	if(i!=(val-1)){
	B_Box[r][c][i]=0;
	}//if
}//for i
change_marks_same_big_box(B_Box,r,c,val);
change_marks_same_row(B_Box,r,c,val);
change_marks_same_column(B_Box,r,c,val);
is_unique(B_Box);
//is_solved(BBBox);

} 

}