| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1434 人关注过本帖
标题:八皇后回溯法代码问题求指点
取消只看楼主 加入收藏
以后不要补考
Rank: 1
等 级:新手上路
帖 子:22
专家分:3
注 册:2010-1-30
结帖率:75%
收藏
已结贴  问题点数:20 回复次数:3 
八皇后回溯法代码问题求指点
#include<stdio.h>


int checkqueen(int array[][8],int x,int y)//是否自对角线上
{
   
    int i,j;
    int r,t;
    i=x;
    j=y;
    r=x-1;
    t=y-1;

    array[i-1][j-1]=1;
    while(i!=0&&j!=0)
    {
        
        if(array[i-1][j-1]=1)
            return 0;
        i--;
        j--;
    }
    while(r!=0&&t!=8)
    {
        if(array[r-1][t+1]=1)
            return 0;
        r--;
        t++;
    }
    return 1;

}


int checkrow(int array[][8],int x,int y)
{
    int row ;
    for(row=x;row>=0;row++)// 是否在同一列上
    {
        if(array[row][y]=1)
            return 0;
    }
    return 1;


}


int placequeen(int s[][8],int array[][8],int x)
{
    int i,j,t;
    if(x>=7)
    {
        for(i=0;i<8;i++)
        {
            for(j=0;j<8;j++)
            {
                printf("%d ",s[i][j]);
            }
            printf("\n");
        }
    }
    else
    {
        for(t=0;t<8;t++)
        {
            array[x][t]=1;
        if(checkqueen(array,x,t) && checkrow(array,x,t))
          placequeen(s,array,x+1);
        else
        {
        array[x][t]=0;
        }
        }
    }
    return 1;
}
void main ()
{
    int sl[8][8]={0};
    int eq[8][8]={0};
    placequeen(sl,eq,0);
}

搜索更多相关主题的帖子: include return 对角线 while 
2011-08-08 10:47
以后不要补考
Rank: 1
等 级:新手上路
帖 子:22
专家分:3
注 册:2010-1-30
收藏
得分:0 
回复 3楼 waterstar
谢谢了 。。
2011-08-09 12:56
以后不要补考
Rank: 1
等 级:新手上路
帖 子:22
专家分:3
注 册:2010-1-30
收藏
得分:0 
回复 4楼 loveshuang
恩 我在看看的回溯法的吧
2011-08-09 12:56
以后不要补考
Rank: 1
等 级:新手上路
帖 子:22
专家分:3
注 册:2010-1-30
收藏
得分:0 
回复 7楼 fragileeye
谢谢 我已经把自己的给改好了。不过还是要学习下大家的思路。。。
2011-08-09 19:18
快速回复:八皇后回溯法代码问题求指点
数据加载中...
 
   



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

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