⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 8queen.c

📁 八皇后的scheme
💻 C
字号:
#include <stdio.h>
#include <stdlib.h>

#define max 8


int queen[max], sum=0; /* max为棋盘最大坐标 */
void show() /* 输出所有皇后的坐标 */
{
    int i,j;
    char a='Q',b='*';
    sum++;
    printf("%s","Solution No. ");
    printf("%d",sum);
    printf("%s",":");
    putchar('\n');
    for(i = 0; i < max; i++)
    {
        printf("%s","(");
        for(j = 0; j < queen[i];j++) putchar(b);
        putchar(a);
        for(j = queen[i]+1; j < max;j++) putchar(b);
        printf("%s",")");
        putchar('\n');          
    }
}
int check(int n) /* 检查当前列能否放置皇后 */
{
    int i;
    for(i = 0; i < n; i++) /* 检查横排和对角线上是否可以放置皇后 */
    {
        if(queen[i] == queen[n] || abs(queen[i] - queen[n]) == (n - i))
        {
            return 1;
        }
    }
    return 0;
}
void put(int n) /* 回溯尝试皇后位置,n为横坐标 */
{
    int i;
    for(i = 0; i < max; i++)
    {       
        queen[n] = i; /* 将皇后摆到当前循环到的位置 */
        if(!check(n))
        {           
            if(n == max - 1)
            {
                show(); /* 如果全部摆好,则输出所有皇后的坐标 */
            }         
            else
            {
                put(n + 1); /* 否则继续摆放下一个皇后 */
            }
        }
    }
}

int main()
{
    put(0); /* 从横坐标为0开始依次尝试 */
    system("pause");
    return 0;
}


⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -