新聞中心

回朔算法2

作者: 時(shí)間:2016-12-01 來(lái)源:網(wǎng)絡(luò) 收藏

void TuiLi::hh_out()
{
//刷新棋盤數(shù)據(jù)
int i,j,z=0;

for(i=0;i{
for(j=0;j{
HH[i][j]=hh[z];
z++;
}
}

}

void TuiLi::hh_print()
{
//輸出問(wèn)題解
int i,j;

for(i=0;i{
printf(" ");
for(j=0;j{
if(HH[i][j]==0) printf("+ ");
else if(HH[i][j]==1) printf("W ");
}
printf("");
}
printf("");
}

int TuiLi::ok_hh(int m)
{
int i,j,x,y;
x=0;
for(i=0;ifor(j=0,x=0;j{
x+=HH[i][j];
if(x>=2) return 1;
}
//不允許行重復(fù)
for(i=0;ifor(j=0,x=0;j{
x+=HH[j][i];
if(x>=2) return 1;
}
//不允許列重復(fù)

for(y=0;y<=(N-1);y++)
{
for(i=y,j=(N-1),x=0;i>=0&&j>=0;i--,j--)
{
x+=HH[i][j];
if(x>=2) return 1;
}
}
for(y=(N-1);y>=0;y--)
{
for(i=y,j=0,x=0;i>=0&&j<=(N-1);i++,j++)
{
x+=HH[i][j];
if(x>=2) return 1;
}
}


for(y=0;y<=(N-1);y++)
{
for(i=y,j=0,x=0;i>=0&&j<=(N+1);i--,j++)
{
x+=HH[i][j];
if(x>=2) return 1;
}
}

for(y=(N-1);y>=0;y--)
{
for(i=y,j=(N-1),x=0;i<=(N-1)&&j>=0;i++,j--)
{
x+=HH[i][j];
if(x>=2) return 1;
}
}
//不允許斜線重復(fù)


return 0;
}

int TuiLi::ok_hh_sc()
{
//最后判斷解是否合法
int i,j,x=0;
for(i=0;ifor(j=0;j{
x+=HH[j][i];
}
if(x==N) return 1;else return 0;
}

int TuiLi::go_hh()
{
//解皇后問(wèn)題
int i,c=0;

hh_init();
hh_out();
//回溯根節(jié)點(diǎn)初始值,調(diào)整這個(gè)值能調(diào)整回溯進(jìn)度
hh[0]=1;
hh_out();
i=0;
while(1)
{
if(hh[i]>=0)
{
//回溯點(diǎn)取值在正常范圍內(nèi)
if(ok_hh(i))
{
//如果和剪枝條件沖突,嘗試下一個(gè)可用值
hh[i]--;
hh_out();
continue;
}
if(i>=(N*N-1))
{
//已經(jīng)到了最后一個(gè)節(jié)點(diǎn)也就是找到了一個(gè)解先輸出它
if(ok_hh_sc()){if(c<=100)hh_print();c++;}
//然后嘗試找到其它的解
hh[(N*N-1)]--;
hh_out();
continue;
}
//回溯點(diǎn)值沒(méi)有產(chǎn)生沖突擴(kuò)展他嘗試開(kāi)始下一個(gè)節(jié)點(diǎn)
i++;
hh[i]=1;
hh_out();

}else
{
//超過(guò)回溯點(diǎn)取值范圍
//此回溯點(diǎn)已死復(fù)位
hh[i]=0;
hh_out();
//退回前一回溯點(diǎn)
i--;
if(i<0)
{
printf("已經(jīng)找出%d皇后問(wèn)題所有解共有:%d個(gè)解!",N,c);
printf("如果皇后問(wèn)題解太多的話就只輸出前面100個(gè)!");

return 1;
}
//嘗試對(duì)上一回溯點(diǎn)進(jìn)行擴(kuò)展
hh[i]--;
hh_out();
continue;
}
}

return 0;
}


上一頁(yè) 1 2 下一頁(yè)

關(guān)鍵詞: 回朔算法題目信

評(píng)論


技術(shù)專區(qū)

關(guān)閉