#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <string.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <sys/wait.h>
#include <fcntl.h>
int vf,pmax,SIZE,size,sudoku[ 25 ] [ 25 ] ;
int isValid( int row,int col,int weight)
{
int i,j,start_row,start_col;
for ( i= 0 ; i< SIZE; i++ )
if ( sudoku[ row] [ i] == weight)
return 0 ;
for ( i= 0 ; i< SIZE; i++ )
if ( sudoku[ i] [ col] == weight)
return 0 ;
start_row= ( row/ size) * size;
start_col= ( col/ size) * size;
for ( i= start_row; i< start_row+ size; i++ )
for ( j= start_col; j< start_col+ size; j++ )
if ( sudoku[ i] [ j] == weight)
return 0 ;
return 1 ;
}
void printSolution( )
{
int i,j;
printf ( "\n " ) ;
for ( i= 0 ; i< SIZE; i++ )
{
for ( j= 0 ; j< SIZE; j++ )
printf ( "%d " ,sudoku[ i] [ j] ) ;
printf ( "\n " ) ;
}
printf ( "\n " ) ;
}
void solveSudoku( int row,int col)
{
int fd2,fd,i,cn,tmp= 0 ,rev,chn= 0 ,anss= 0 ;
//printf("hi ");
fd2= open( "tmp2" ,O_RDWR| O_CREAT) ;
flock( fd2,LOCK_EX) ;
read( fd2,& anss,sizeof ( anss) ) ;
printf ( "anss= %d\n " ,anss) ;
flock( fd2,LOCK_UN) ;
close( fd2) ;
if ( anss== 1 ) _exit( 1 ) ;
if ( row== SIZE && col== 0 )
{
//printf("aaa\n");
anss= 1 ;
fd2= open( "tmp2" ,O_RDWR| O_CREAT) ;
//flock(fd2,LOCK_EX);
write( fd2,& anss,sizeof ( anss) ) ;
printSolution( ) ;
flock( fd2,LOCK_UN) ;
close( fd2) ;
_exit( 1 ) ;
}
else
{
if ( sudoku[ row] [ col] ! = 0 ) //encounters a pre-filled cell.
{
if ( col== SIZE- 1 ) solveSudoku( row+ 1 ,0 ) ;
else solveSudoku( row,col+ 1 ) ;
}
else
for ( i= 1 ; i<= SIZE; i++ )
if ( isValid( row,col,i) && sudoku[ row] [ col] == 0 )
{
fd= open( "tmp" ,O_RDWR| O_CREAT) ;
flock( fd,LOCK_EX) ;
read( fd,& cn,sizeof ( cn) ) ;
printf ( "cn pre=%d\n " ,cn) ;
if ( cn= pmax)
{
sudoku[ row] [ col] = i;
printf ( "cn no fork=%d\n " ,cn) ;
flock( fd,LOCK_UN) ;
close( fd) ;
if ( col== SIZE- 1 ) solveSudoku( row+ 1 ,0 ) ;
else solveSudoku( row,col+ 1 ) ;
sudoku[ row] [ col] = 0 ;
//_exit(0);
}
else if ( cn< pmax && cn>= 0 )
{
cn++ ;
//flock(fd,LOCK_EX);
write( fd,& cn,4 ) ;
printf ( "cn after=%d\n " ,cn) ;
flock( fd,LOCK_UN) ;
close( fd) ;
pid_t cpid;
cpid= fork( ) ;
if ( cpid== - 1 )
{
sudoku[ row] [ col] = i;
if ( col== SIZE- 1 ) solveSudoku( row+ 1 ,0 ) ;
else solveSudoku( row,col+ 1 ) ;
sudoku[ row] [ col] = 0 ;
}
else
if ( cpid== 0 )
{
sudoku[ row] [ col] = i;
if ( col== SIZE- 1 ) solveSudoku( row+ 1 ,0 ) ;
else solveSudoku( row,col+ 1 ) ;
_exit( 0 ) ;
}
else
if ( cpid> 0 ) chn++ ;
} //cn<pmax
} //for all possible
{
//printf("chn=%d\n",chn);
while ( chn-- ) {
wait( & rev) ;
//if (rev>0) printf("rev%d\n",rev);
//if (tmp==1) _exit(1);
if ( WIFEXITED( rev) )
{
tmp= WEXITSTATUS( rev) ;
if ( tmp== 1 )
{
anss= 1 ;
_exit( 1 ) ;
//break;
}
else
if ( tmp== 0 )
{
printf ( "*" ) ;
fd= open( "tmp" ,O_RDWR| O_CREAT) ;
flock( fd,LOCK_EX) ;
read( fd,& cn,sizeof ( cn) ) ;
printf ( "cnp=%d" ,cn) ;
cn-- ;
write( fd,& cn,sizeof ( cn) ) ;
printf ( "cnaf=%d" ,cn) ;
flock( fd,LOCK_UN) ;
close( fd) ;
}
}
} //chn--
} //parent process
}
}
int main( int argc,char * argv[ ] )
{
int i,j,fd,fd2;
for ( i= 0 ; i<= 2 ; i++ )
{
j= 2 * i+ 1 ;
if ( strcmp ( argv[ j] ,"-m" ) == 0 )
{
if ( strcmp ( argv[ j+ 1 ] ,"vfork" ) == 0 ) vf= 1 ;
else vf= 0 ;
}
if ( strcmp ( argv[ j] ,"-n" ) == 0 )
{
SIZE= atoi ( argv[ j+ 1 ] ) ;
}
if ( strcmp ( argv[ j] ,"-p" ) == 0 )
{
pmax= atoi ( argv[ j+ 1 ] ) ;
}
}
printf ( "vf=%d " ,vf) ;
printf ( "pmax=%d " ,pmax) ;
printf ( "SIZE=%d\n " ,SIZE) ;
//scanf("%d",&SIZE);
size= SIZE; SIZE* = SIZE;
for ( i= 0 ; i< SIZE; i++ )
for ( j= 0 ; j< SIZE; j++ )
scanf ( "%d" ,& sudoku[ i] [ j] ) ;
printSolution( ) ; //Display inputted sudoku from the file
i= 0 ;
fd2= open( "tmp4" ,O_RDWR| O_CREAT) ;
//flock(fd2,LOCK_EX);
write( fd2,& i,4 ) ;
printf ( "tmp4=%d\n " ,i) ;
//flock(fd2,LOCK_UN);
//close(fd2);
//------------------
/*
fd=open("tmp",O_RDWR|O_CREAT);
flock(fd,LOCK_EX);
write(fd,&i,sizeof(i));
read(fd,&i,4);
read(fd,&j,4);
printf("tmp=%d %d\n",i,j);
flock(fd,LOCK_UN);
close(fd);
char buf[100];
fd=open("tmp",O_RDWR|O_CREAT);
flock(fd,LOCK_EX);
read(fd,buf,4);
printf("tmp=%s\n",buf);
flock(fd,LOCK_UN);
close(fd);
solveSudoku(0,0);*/
return 0 ;
}
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <string.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <sys/wait.h>
#include <fcntl.h>


int vf,pmax,SIZE,size,sudoku[25][25];

int isValid(int row,int col,int weight)
{
        int i,j,start_row,start_col;
        for(i=0;i<SIZE;i++)
                if(sudoku[row][i]==weight)
                        return 0;

        for(i=0;i<SIZE;i++)
                if(sudoku[i][col]==weight)
                        return 0;

        start_row=(row/size)*size;
        start_col=(col/size)*size;
        for(i=start_row;i<start_row+size;i++)
                for(j=start_col;j<start_col+size;j++)
                        if(sudoku[i][j]==weight)
                                return 0;
        return 1;
}

void printSolution()
{
        int i,j;
        printf("\n");
        for(i=0;i<SIZE;i++)
        {
                for(j=0;j<SIZE;j++)
                        printf("%d ",sudoku[i][j]);
                printf("\n");
        }
        printf("\n");
}

void solveSudoku(int row,int col)
{
   int fd2,fd,i,cn,tmp=0,rev,chn=0,anss=0;
   //printf("hi ");
   fd2=open("tmp2",O_RDWR|O_CREAT);
   flock(fd2,LOCK_EX);
   read(fd2,&anss,sizeof(anss));
   printf("anss=  %d\n",anss);
   flock(fd2,LOCK_UN);
   close(fd2);
   if (anss==1) _exit(1);
        if(row==SIZE && col==0)
              {
                //printf("aaa\n");
                anss=1;
                fd2=open("tmp2",O_RDWR|O_CREAT);
                //flock(fd2,LOCK_EX);
                write(fd2,&anss,sizeof(anss));
                printSolution();
                flock(fd2,LOCK_UN);
                close(fd2);
                _exit(1);
              }
        else
        {
                if(sudoku[row][col]!=0)    //encounters a pre-filled cell.
                {
                        if (col==SIZE-1) solveSudoku(row+1,0);
                         else solveSudoku(row,col+1);
                }
                else
                        for(i=1;i<=SIZE;i++)
                                if( isValid(row,col,i) && sudoku[row][col]==0)
                                {
                                        fd=open("tmp",O_RDWR|O_CREAT);
                                        flock(fd,LOCK_EX);
                                        read(fd,&cn,sizeof(cn));
                                        printf("cn pre=%d\n",cn);
                                        if (cn=pmax)
                                        {
                                           sudoku[row][col]=i;
                                           printf("cn no fork=%d\n",cn);
                                           flock(fd,LOCK_UN);
                                           close(fd);
                                           if(col==SIZE-1) solveSudoku(row+1,0);
                                             else solveSudoku(row,col+1);
                                           sudoku[row][col]=0;
                                           //_exit(0);
                                        }
                                        else if (cn<pmax && cn>=0)
                                        {
                                           cn++;
                                           //flock(fd,LOCK_EX);
                                           write(fd,&cn,4);
                                           printf("cn after=%d\n",cn);
                                           flock(fd,LOCK_UN);
                                           close(fd);
                                           pid_t cpid;
                                           cpid=fork();
                                        if (cpid==-1)
                                        {
                                           sudoku[row][col]=i;
                                           if(col==SIZE-1) solveSudoku(row+1,0);
                                             else solveSudoku(row,col+1);
                                           sudoku[row][col]=0;
                                        }
                                         else
                                        if (cpid==0)
                                        {
                                           sudoku[row][col]=i;
                                           if(col==SIZE-1) solveSudoku(row+1,0);
                                             else solveSudoku(row,col+1);
                                           _exit(0);
                                        }
                                       else
                                        if (cpid>0) chn++;
                                     }//cn<pmax
                                } //for all possible
                                  {
                                     //printf("chn=%d\n",chn);
                                     while(chn--){
                                             wait(&rev);
                                              //if (rev>0) printf("rev%d\n",rev);
                                              //if (tmp==1) _exit(1);
                                              if (WIFEXITED(rev))
                                                 {
                                                     tmp=WEXITSTATUS(rev);
                                                     if (tmp==1)
                                                     {
                                                         anss=1;
                                                         _exit(1);
                                                         //break;
                                                     }
                                                     else
                                                      if (tmp==0)
                                                      {
                                                          printf("*");
                                                          fd=open("tmp",O_RDWR|O_CREAT);
                                                          flock(fd,LOCK_EX);
                                                          read(fd,&cn,sizeof(cn));
                                                          printf("cnp=%d",cn);
                                                          cn--;
                                                          write(fd,&cn,sizeof(cn));
                                                          printf("cnaf=%d",cn);
                                                          flock(fd,LOCK_UN);
                                                          close(fd);
                                                      }
                                                 }
                                          }//chn--
                                  }//parent process
        }
}

int main(int argc,char* argv[])
{
        int i,j,fd,fd2;
        for (i=0;i<=2;i++)
        {
            j=2*i+1;
            if (strcmp(argv[j],"-m")==0)
             {
                if (strcmp(argv[j+1],"vfork")==0) vf=1;
                 else vf=0;
             }
            if (strcmp(argv[j],"-n")==0)
             {
                SIZE=atoi(argv[j+1]);
             }
            if (strcmp(argv[j],"-p")==0)
             {
                pmax=atoi(argv[j+1]);
             }
        }
        printf("vf=%d ",vf);
        printf("pmax=%d ",pmax);
        printf("SIZE=%d\n",SIZE);
        //scanf("%d",&SIZE);
        size=SIZE;  SIZE*=SIZE;
        for (i=0;i<SIZE;i++)
         for (j=0;j<SIZE;j++)
           scanf("%d",&sudoku[i][j]);
          printSolution();  //Display inputted sudoku from the file


        i=0;
        fd2=open("tmp4",O_RDWR|O_CREAT);
        //flock(fd2,LOCK_EX);
        write(fd2,&i,4);
        printf("tmp4=%d\n",i);
        //flock(fd2,LOCK_UN);
        //close(fd2);
//------------------
        /*
        fd=open("tmp",O_RDWR|O_CREAT);
        flock(fd,LOCK_EX);
        write(fd,&i,sizeof(i));
        read(fd,&i,4);
        read(fd,&j,4);
        printf("tmp=%d %d\n",i,j);
        flock(fd,LOCK_UN);
        close(fd);
        char buf[100];
        fd=open("tmp",O_RDWR|O_CREAT);
        flock(fd,LOCK_EX);
        read(fd,buf,4);
        printf("tmp=%s\n",buf);
        flock(fd,LOCK_UN);
        close(fd);

        solveSudoku(0,0);*/
        return 0;
}

compilation info
prog.cpp: In function ‘void solveSudoku(int, int)’:
prog.cpp:51: error: no matching function for call to ‘flock::flock(int&, int)’
/usr/include/bits/fcntl.h:145: note: candidates are: flock::flock()
/usr/include/bits/fcntl.h:145: note: flock::flock(const flock&)
prog.cpp:54: error: no matching function for call to ‘flock::flock(int&, int)’
/usr/include/bits/fcntl.h:145: note: candidates are: flock::flock()
/usr/include/bits/fcntl.h:145: note: flock::flock(const flock&)
prog.cpp:65: error: no matching function for call to ‘flock::flock(int&, int)’
/usr/include/bits/fcntl.h:145: note: candidates are: flock::flock()
/usr/include/bits/fcntl.h:145: note: flock::flock(const flock&)
prog.cpp:81: error: no matching function for call to ‘flock::flock(int&, int)’
/usr/include/bits/fcntl.h:145: note: candidates are: flock::flock()
/usr/include/bits/fcntl.h:145: note: flock::flock(const flock&)
prog.cpp:84: warning: suggest parentheses around assignment used as truth value
prog.cpp:88: error: no matching function for call to ‘flock::flock(int&, int)’
/usr/include/bits/fcntl.h:145: note: candidates are: flock::flock()
/usr/include/bits/fcntl.h:145: note: flock::flock(const flock&)
prog.cpp:101: error: no matching function for call to ‘flock::flock(int&, int)’
/usr/include/bits/fcntl.h:145: note: candidates are: flock::flock()
/usr/include/bits/fcntl.h:145: note: flock::flock(const flock&)
prog.cpp:144: error: no matching function for call to ‘flock::flock(int&, int)’
/usr/include/bits/fcntl.h:145: note: candidates are: flock::flock()
/usr/include/bits/fcntl.h:145: note: flock::flock(const flock&)
prog.cpp:150: error: no matching function for call to ‘flock::flock(int&, int)’
/usr/include/bits/fcntl.h:145: note: candidates are: flock::flock()
/usr/include/bits/fcntl.h:145: note: flock::flock(const flock&)
prog.cpp:52: warning: ignoring return value of ‘ssize_t read(int, void*, size_t)’, declared with attribute warn_unused_result
prog.cpp:63: warning: ignoring return value of ‘ssize_t write(int, const void*, size_t)’, declared with attribute warn_unused_result
prog.cpp:82: warning: ignoring return value of ‘ssize_t read(int, void*, size_t)’, declared with attribute warn_unused_result
prog.cpp:99: warning: ignoring return value of ‘ssize_t write(int, const void*, size_t)’, declared with attribute warn_unused_result
prog.cpp:145: warning: ignoring return value of ‘ssize_t read(int, void*, size_t)’, declared with attribute warn_unused_result
prog.cpp:148: warning: ignoring return value of ‘ssize_t write(int, const void*, size_t)’, declared with attribute warn_unused_result
prog.cpp: In function ‘int main(int, char**)’:
prog.cpp:161: warning: unused variable ‘fd’
prog.cpp:186: warning: ignoring return value of ‘int scanf(const char*, ...)’, declared with attribute warn_unused_result
prog.cpp:193: warning: ignoring return value of ‘ssize_t write(int, const void*, size_t)’, declared with attribute warn_unused_result
stdout