鱼C论坛

 找回密码
 立即注册
查看: 2118|回复: 2

为什么n>=10的 n皇后问题算不出来?

[复制链接]
发表于 2018-9-28 18:04:48 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
RT。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2018-9-28 19:41:57 | 显示全部楼层
内存满了?不至于吧?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-9-28 20:58:35 | 显示全部楼层
claws0n 发表于 2018-9-28 19:41
内存满了?不至于吧?
int Count=0;       //方法计数
int FirstRow=0;   //第一行皇后位置
int RowIsOk=0;  
int IsNotDanger(int row,int col)
{
    if(chess[row][col]==-1)return 0;   //当前位置
    for(int m=0;m<row;m++)
        if(chess[m][col]==1)return 0;  //列
    for(int m=row-1,n=col-1;m>=0&&n>=0;m--,n--)
        if(chess[m][n]==1)return 0;    //左上角
    for(int m=row-1,n=col+1;m>=0&&n<N;m--,n++)
        if(chess[m][n]==1)return 0;    //右上角
    for(int m=row+1,n=col-1;m<N&&n>=0;m++,n--)
        if(chess[m][n]==1)return 0;    //左下角
    for(int m=row+1,n=col+1;m<N&&n<N;m++,n++)
        if(chess[m][n]==1)return 0;    //左上角
    return 1;
}
void Queen2(int row)
{
    if(FirstRow==N)return;
    RowIsOk=0;
    if(row==N)
    {
        Count++;
        printf("第 %d 种:\n",Count);
        for(int i=0;i<N;i++)
        {
            for(int j=0;j<N;j++)
            {
                if(chess[i][j]==1)
                    printf("%d ",chess[i][j]);
               else printf("0 ");
            }
            cout<<endl;
        }
        for(int j=0;j<N;j++)
            if(chess[row-1][j]==1)chess[row-1][j]=-1;
    }
    else
    {
        for(int j=0;j<N;j++)
            if(IsNotDanger(row,j))
            {
                RowIsOk=1;
                chess[row][j]=1;
                Queen2(row+1);
            }
        if(!RowIsOk)
        {
            for(int j=0;j<N;j++)
                if(chess[row-1][j]==1)
                {
                    chess[row-1][j]=-1;
                    break;
                }
            for(int j=0;j<N;j++)chess[row][j]=0;
            if(row==1)FirstRow++;
            Queen2(row-1);
        }
    }
}
int main()
{
    for(int i=0;i<N;i++)
        for(int j=0;j<N;j++)
            chess[i][j]=0;
    Queen2(0);
    return 0;
}
麻烦帮我看一下,谢谢!
N<10的时候一切正常,N>=10就计算不出来了。

N=9

N=9

N=10

N=10

N=8

N=8
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-12-24 02:34

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表