八皇后

#define _CRT_SECURE_N0_WARNINGS 1
#include<stdio.h>
#define N 8
//八皇后问题
char board[N + 2][N + 2];
int counter = 0;

void init(void)
{
    //初始化边界
    for (int row = 0; row < N + 2; row++){
        for (int col = 0; col < N + 2; col++){
            board[0][col] = '#';
            board[N + 1][col] = '#';
            board[row][0] = '#';
            board[row][N + 1] = '#';
        }
    }
    //初始化内部
    for (int i = 1; i <= N; i++)
    {
        for (int j = 1; j <= N; j++){
            board[i][j] = ' ';
        }
    }
}

//显示棋盘
void show(void)
{
    for (int i = 0; i < N + 2; i++)
    {
        for (int j = 0; j < N + 2; j++)
        {
            printf("%c ",board[i][j]);
        }
        printf("\n");
    }
}

//相对于当前位置的偏移量
struct Pos{
    int ros; //行偏移量
    int cos;//列偏移量
};
struct Pos pos[3] = { { -1, -1 }, { -1, 0 }, {-1,1} };


//测试row行col列是否可以摆放皇后
int check(int row, int col)
{
    int new_row, new_col;
    int ret = 1;
    for (int i = 0; i < 3 && ret; i++)
    {
        new_row = row;
        new_col = col;
        while (ret&&board[new_row][new_col] != '#')
        {
            if (board[new_row][new_col] == '*')
            {
                ret = 0;
                break;
            }
            new_row = new_row + pos[i].ros;
            new_col = new_col + pos[i].cos;
        }
    }
    return ret;
}
//找合适位置摆放皇后
//回溯算法
void find(int row)
{
    if (row > N)
    {
        show();
        counter++;
        printf("%d\n",counter);
    }
    else
    {
        for (int col = 1; col <= N; col++)
        {
            if (check(row, col))
            {
                board[row][col] = '*';
                find(row + 1);
                board[row][col] = ' ';
            }
        }
    }

}

int main()
{
    init();
    find(1); //从第一行开始找
    return 0;
}

运行结果(92种):
八皇后.png
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 一、用枚举法实现思路:枚举所有的可能来,可以看成一个树形结构,到了叶子节点再去判断是不是可行解 二、用回溯法实现思...
    Tonyliu_阅读 827评论 0 1
  • 最近接触到八皇后问题,看了下其中一种思路还挺简单,就是全排列然后筛选出斜边也满足的排列方法。比较麻烦的是全排列,特...
    Cracks_Yi阅读 214评论 0 0
  • 八皇后问题,是一个古老而著名的问题,是回溯算法的典型案例。 问题的内容是在国际象棋棋盘上(8*8),放置八个皇后并...
    没了帽子的Link阅读 832评论 1 1
  • 问题介绍 摘自百度百科八皇后问题,是一个古老而著名的问题,是回溯算法的典型案例。该问题是国际西洋棋棋手马克斯·贝瑟...
    逍遥wqy阅读 1,132评论 0 0
  • 问题描述: 在8x8的网格上,放置皇后两个皇后,两个皇后之间不能在同一行,也不能在同一列,也不能在对角线上。 cl...
    一见有血阅读 532评论 0 0