标题:[求助]谁能给我个用C的8皇后问题
只看楼主
罗嘧欧
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2006-7-4
 问题点数:0 回复次数:1 
[求助]谁能给我个用C的8皇后问题
谁能给我个用C的8皇后问题,本人是初学者希望谁能帮帮我
搜索更多相关主题的帖子: 皇后 
2006-07-04 21:36
xigezai218
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2013-11-11
得分:0 
#include <math.h>
#include <stdio.h>
#define MAX 8 /* 棋子数及棋盘大小MAXxMAX */
int board[MAX];

/* 印出結果 */
void show_result()
{
    int i;
    for(i=0;i<MAX;i++)
    printf("(%d,%d)",i,board[i]);
    printf("\n");
}

/* 检查是否在同一直橫斜线上有其它棋子 */
int check_cross(int n)
{
    int i;
    for(i=0;i<n;i++){
    if(board[i]==board[n] || (n-i)==abs(board[i]-board[n]))return 1;
    }
    return 0;
}

/* 放棋子到棋盘上 */
void put_chess(int n)
{
    int i;
    for(i=0;i<MAX;i++){
    board[n]=i;
    if(!check_cross(n)){
        if(n==MAX-1) show_result();/* 找到其中一种放法了...印出結果 */
        else put_chess(n+1);
    }
    }
}

void main()
{
    clrscr();
    puts("The possible placements are:");
    put_chess(0);
    puts("\n Press any key to quit...");
    getch();
    return;
}

2013-11-11 13:39



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-76566-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.406501 second(s), 7 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved