八皇后

作者: 修夏之夏i | 来源:发表于2018-05-15 23:41 被阅读17次
#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

相关文章

  • Gym - 100947B 八皇后变形题

    题意:就是八皇后问题的变形,给你八个皇后的位置,问是否满足八皇后的摆放.注: 任意皇后可以攻击同一行,同一列,同一...

  • 11.数据结构—八皇后问题(回溯法)

    11.1 八皇后问题 八皇后问题是以国际象棋为背景的问题:有八个皇后(可以当成八个棋子),如何在 88 的棋盘中放...

  • 媳妇多就用分支修剪,解决婆娘纷争,C语言经典算法之八皇后问题

    八皇后问题 西洋棋中的皇后可以直线前进,吃掉遇到的所有棋子,如果棋盘上有八个皇后,则这八个皇后如何相安无事的放置在...

  • 八皇后&N皇后

    八皇后 二维数组TLE 优化 设i为行,j为列,从图可验证:*如果在同一列,列号相同*若果同在/斜线上,行列值之和...

  • 算法(03)回溯

    八皇后问题

  • 八皇后

    什么是八皇后问题? 八皇后问题是一个古老的问题,于1848年由一位国际象棋棋手提出:在8×8格的国际象棋上摆放八个...

  • 八皇后

  • 八皇后

  • 八皇后

    法一矩阵维护法,思路相对简单的方法 cheese_table为8*8的棋盘,queen数组记录八个皇后各自的列数(...

  • 八皇后

    问题一 判断是否在同一条斜线是否在同一条斜线就是两个点p(a,b),q(c,d)形成的斜率是否为正负11)斜率为1...

网友评论

    本文标题:八皇后

    本文链接:https://www.haomeiwen.com/subject/xududftx.html