| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 532 人关注过本帖
标题:八皇后问题
只看楼主 加入收藏
一霎流光
该用户已被删除
收藏
 问题点数:0 回复次数:2 
八皇后问题
提示: 作者被禁止或删除 内容自动屏蔽
搜索更多相关主题的帖子: 皇后 
2010-05-03 13:45
寒风中的细雨
Rank: 17Rank: 17Rank: 17Rank: 17Rank: 17
等 级:贵宾
威 望:66
帖 子:1710
专家分:8645
注 册:2009-9-15
收藏
得分:0 
#include<iostream>
using namespace std;

int board[8] = {0,0,0,0,0,0,0,0};
void print_board();
int illegal(int);
void eight_queen(int);
int main()
{  
        eight_queen(0);
    return 0;
}
void eight_queen(int i)
{
    if (i >= 8)
        print_board();
    else
        for (int j=0; j<8; j++)
        {
            board[i] = j;
            if ( !illegal(i) )
                eight_queen(i+1);
        }
}
int  illegal(int n)
{
    for (int i=0; i< n; i++)
        for (int j=i+1; j <= n; j++)
        {
            if (board[i] == board[j] ||
                abs(board[i]-board[j]) == abs(i-j) )//board[i] == board[j]是为了保证不在一列上
                return 1;            //abs(board[i]-board[j]) == abs(i-j)保证不再对角线上
        }
    return 0;
}
void print_board()
{
    static int cnt = 1;
    printf("ANS: %d\n", cnt++);
    for (int i=0; i<8; i++)
    {
        for (int j=0; j<8; j++)
            if (j==board[i])
                printf(" X");
            else
                printf(" -");
        cout << endl;
    }
}
2010-05-30 18:45
寒风中的细雨
Rank: 17Rank: 17Rank: 17Rank: 17Rank: 17
等 级:贵宾
威 望:66
帖 子:1710
专家分:8645
注 册:2009-9-15
收藏
得分:0 
92
2010-05-30 18:46
快速回复:八皇后问题
数据加载中...
 
   



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

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