| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1052 人关注过本帖
标题:八皇后问题输出的问题
只看楼主 加入收藏
没事跳楼耍
Rank: 1
等 级:新手上路
帖 子:20
专家分:0
注 册:2007-3-19
收藏
 问题点数:0 回复次数:1 
八皇后问题输出的问题
下面是我写的递归回溯程序,要求输出八皇后问题的一种解,但是这个程序总是输出全部解,不知道哪里出问题了,恳请大家的帮助
bool is_partial(array<int> &x,int k){//判断x[0], x[2], …, x[k]是否为部分解
    int i=0;
    while(i<k){
        if(x[i]==x[k]||abs(x[i]-x[k])==abs(i-k))//x[i]和x[k]处于同一列或x[i]和x[k]处于一条斜线上
            return false;
        i++;
    }
    return true;
}


void queens_advance(int k,array<int> &x,int n,bool flag){
     int m;
     for(m=1;m<=n;m++){
          x[k]=m;
          if(is_partial(x,k)&&!flag){//若为部分解
               if(k==n-1){//若为合法解
                    flag=true;
                    //return flag;
                    //break;
                    cout<<x<<endl;
                    return;
               }
               else
                    queens_advance(k+1,x,n,flag);
          }
     }
}

void queens_rec(int n){
     array<int> x(n);//解向量
     bool flag=false;//合法解标志
     queens_advance(0,x,n,flag);
     //if(flag)
     //     cout<<x<<endl;
     //else
     //     cout<<"no solution"<<endl;
}

[[italic] 本帖最后由 没事跳楼耍 于 2007-11-29 15:55 编辑 [/italic]]
搜索更多相关主题的帖子: 皇后问题 int bool 输出 array 
2007-11-29 15:54
diaoxue
Rank: 1
等 级:新手上路
帖 子:142
专家分:0
注 册:2007-6-1
收藏
得分:0 
回溯法:
#include <iostream>
#include <cmath>//in vc 6.0
using namespace std;
const int n=8;
int t=1;
int x[n+1];//don't use x[0]
int bestx[n+1];//don't use bestx[0]
long sum=0;
bool Place(int k)
{
    for(int j=1;j<k;j++)
    {
        if(abs(k-j)==abs(x[k]-x[j]) || x[j]==x[k])//不符合条件 返回假
            return false;
    }
    return true;
    
}
void QueenTB(int t)
{
    if(t>n)
    {
        sum++;
        for(int j=1;j<=n;j++)//更新记录,输出
        {
            bestx[j]=x[j];
            cout<<bestx[j]<<"\t";
        }
        cout<<endl;
    }
    else
    {
        for(int i=1;i<=n;i++)
        {
            x[t]=i;
            if(Place(t))QueenTB(t+1);
        }
    }
}
int main()
{
    QueenTB(t);
    cout<<sum;
    cout<<endl;
//    for(int i=1;i<=n;i++)
//        cout<<bestx[i]<<"\t";
//    cout<<endl;
    return 0;
}

上善若水,水善利万物而不争,处众人之所恶
2007-11-30 20:25
快速回复:八皇后问题输出的问题
数据加载中...
 
   



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

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