Skip to main content

8 Queens Problem

8 Queen problem is a problem in which we have to place 8 Queens on 8x8 chessboard such that no two Queens attack each other.For placing the queens Backtrack Algorithm is used.Let us know first what is backtrack algorithm.

Backtrack Algorithm : Backtrack algorithms uses a incremental technique to arrive at a final solution.It will take the candidate as valid and check all the constraints,if the solution is possible then it moves forward or else it will abandons it when it determines that solution is not possible taking the present candidate.

How backtracking is helpful in the case of 8 Queens problem??

We will be going to place all the Queens in columns one by one from the leftmost column.When we will be placing the queens in the column we will check the constraints like if there is another queen in the row or column or diagonally.If we find a row that is valid and we can place a queen in that then we will take that row and column as a part of the solution.But if we cannot find such row and column then we backtrack and return false.

Algorithm : 

1) Start with the leftmost column
2) If all the queens are placed in right position return True.
3) Try out all the rows in  the present column.If the queen can be safely placed in that row then mark this row and column as a part of the solution and recursively check that by placing the queen in that position will lead to the valid solution.
4) If placing queen in that particular row column results in a valid solution after applying recursion then return True
5) If placing queen in that particular row column does not lead to a valid solution then return False and check for next possibility.
6) If all the rows are tried for the present column and nothing worked then backtrack and return False.

Program :

int main()
{
int chess[8][8]={ {0,0,0,0,0,0,0,0},
      {0,0,0,0,0,0,0,0},
      {0,0,0,0,0,0,0,0},
      {0,0,0,0,0,0,0,0},
      {0,0,0,0,0,0,0,0},
      {0,0,0,0,0,0,0,0},
      {0,0,0,0,0,0,0,0},
      {0,0,0,0,0,0,0,0},
};
if(!8queenproblem(chess,0))    /*If solution does not exist return false */
return false;
}
bool 8queenproblem(int c[8][8],col)
{
if(col>=8)    /*If all Queens are placed */
return true;
for(int i=0;i<8;i++)   /*Try each rows one by one*/
{
if(valid(c,i,col))        /*if valid then make it 1*/
{
c[i][col]=1;
if(8queenproblem(c,col+1))  /*If results in valid solution after recursion then return true*/
return true;
c[i][col]=0;                         /*If not then make it again 0 and backtrack*/
}
}
return false;                      
}
bool valid(int c[8][8],int row,int col)
{
for(int i=0;i<col;i++)   /* Check rows on left side of present column*/
{
if(c[row][i])
return false;

for (i = row, j = col; i >= 0 && j >= 0; i--, j--)  /* Check upper diagonal on left side */
    {
        if (c[i][j])
            return false;
    }

   
    for (i = row, j = col; j >= 0 && i < 8; i++, j--) /* Check lower diagonal on left side */
    {
        if (c[i][j])
            return false;
    }

    return true;

}
}

Here is one of the solution of 8 Queen problem.






Comments

Popular posts from this blog

Tricky Questions or Puzzles in C ( Updated for 2026)

Updated for 2026 This article was originally written when C/C++ puzzles were commonly asked in interviews. While such language-specific puzzles are less frequent today, the problem-solving and logical reasoning skills tested here remain highly relevant for modern Software Engineering, Data Engineering, SQL, and system design interviews . Why These Puzzles Still Matter in 2026 Although most Software &   Data Engineering interviews today focus on Programming, SQL, data pipelines, cloud platforms, and system design , interviewers still care deeply about how you think . These puzzles test: Logical reasoning Edge-case handling Understanding of execution flow Ability to reason under pressure The language may change , but the thinking patterns do not . How These Skills Apply to Data Engineering Interviews The same skills tested by C/C++ puzzles appear in modern interviews as: SQL edge cases and NULL handling Data pipeline failure scenarios Incremental vs ...

Program to uncompress a string ie a2b3c4 to aabbbcccc

Below is the program to uncompress a string #include<stdio.h> #include<conio.h> #include<stdlib.h> int main() { char str[100]="a2b3c4d8u7"; for(int i=0;str[i]!='\0';i++) { if(i%2!=0) { for(int j=0;j<atoi(&str[i]);j++) { printf("%c",str[i-1]); } } } getch(); } Want to become a Data Engineer? Check out below blog posts  1.  5 Key Skills Every Data Engineer needs in 2023 2.  How to prepare for Data Engineering Interviews 3.  Top 25 Data Engineer Questions

Programs and Puzzles in technical interviews i faced

I have attended interview of nearly 10 companies in my campus placements and sharing their experiences with you,though i did not got selected in any of the companies but i had great experience facing their interviews and it might help you as well in preparation of interviews.Here are some of the puzzles and programs asked to me in interview in some of the good companies. 1) SAP Labs I attended sap lab online test in my college through campus placements.It had 3 sections,the first one is usual aptitude questions which i would say were little tricky to solve.The second section was Programming test in which you were provided snippet of code and you have to complete the code (See Tricky Code Snippets  ).The code are from different data structures like Binary Tree, AVL Tree etc.Then the third section had questions from Database,OS and Networks.After 2-3 hours we got the result and i was shortlisted for the nest round of interviews scheduled next day.Then the next day we had PPT of t...