久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

專(zhuān)注電子技術(shù)學(xué)習(xí)與研究
當(dāng)前位置:單片機(jī)教程網(wǎng) >> MCU設(shè)計(jì)實(shí)例 >> 瀏覽文章

回朔算法2

作者:佚名   來(lái)源:本站原創(chuàng)   點(diǎn)擊數(shù):  更新時(shí)間:2013年12月27日   【字體:

void TuiLi::SD_in()
{
//獲取題目信息
int data[]={0,5,0,0,3,0,0,0,0,
0,0,1,6,0,0,9,0,8,
3,0,0,0,0,0,0,0,0,
0,0,0,8,0,0,0,0,0,
0,0,0,0,0,0,7,0,0,
0,0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,0};
int i,j,z=0;
for(i=0;i<9;i++)
for(j=0;j<9;j++)
{
SD[i][j]=data[z];
z++;
}
sd_in();

}

void TuiLi::sd_out()
{
int i,j,z=0;
for(i=0;i<9;i++)
for(j=0;j<9;j++)
{
SD[i][j]=sudu[z];
z++;
}
}

void TuiLi::sd_print()
{
int i,j,z=0;
sd_out();
GetLocalTime(&TIME);//獲得系統(tǒng)當(dāng)前時(shí)間
printf("\n找到一個(gè)數(shù)獨(dú)解獲取時(shí)間為:%d年%d月%d日%d時(shí)%d分%d秒\n",TIME.wYear,TIME.wMonth,TIME.wDay,TIME.wHour,TIME.wMinute,TIME.wSecond);
for(i=0;i<9;i++)
{
printf(" ");
for(j=0;j<9;j++)
{
printf("%d ",SD[i][j]);

}
printf("\n");
}
printf("\n");
}

int TuiLi::ok_sd() //解數(shù)獨(dú)用剪枝函數(shù)
{
int i,j,x;
sd_out();

for(x=0;x<9;x++)
for(i=0;i<9;i++)
for(j=i+1;j<9;j++)
{
if(SD[x][i]==SD[x][j]&&SD[x][i]!=0) return 1;
}
//不允許行重復(fù)

for(x=0;x<9;x++)
for(i=0;i<9;i++)
for(j=i+1;j<9;j++)
{
if(SD[i][x]==SD[j][x]&&SD[i][x]!=0) return 1;
}
//不允許列重復(fù)

return 0;
}

int TuiLi::go_sd() //解數(shù)獨(dú)入口函數(shù)
{
int i,c=0;
//獲取題目信息
SD_in();
//回溯根節(jié)點(diǎn)初始值,調(diào)整這個(gè)值能調(diào)整回溯進(jìn)度
if(!sudu_ji[0])sudu[0]=1;
i=0;
while(1)
{
//sd_print();
//Sleep(10);
if(sudu[i]<=9)
{
//回溯點(diǎn)取值在正常范圍內(nèi)
if(ok_sd())
{
//如果和剪枝條件沖突,嘗試下一個(gè)可用值
if(!sudu_ji[i])sudu[i]++;
continue;
}
if(i>=80)
{
//已經(jīng)到了最后一個(gè)節(jié)點(diǎn)也就是找到了一個(gè)解先輸出它
sd_print();
//然后嘗試找到其它的解
if(!sudu_ji[80])sudu[80]++;
c++;
if(c>=10)
{
printf("此題解太多只輸出前面10個(gè)解!\n\n");
return 0;
}
continue;
}
//回溯點(diǎn)值沒(méi)有產(chǎn)生沖突擴(kuò)展他嘗試開(kāi)始下一個(gè)節(jié)點(diǎn)
i++;
if(!sudu_ji[i])sudu[i]=1;
}else
{
//超過(guò)回溯點(diǎn)取值范圍
//此回溯點(diǎn)已死復(fù)位
if(!sudu_ji[i])sudu[i]=0;
//退回前一回溯點(diǎn)
i--;
if(sudu_ji[i]) i--;//回溯后的當(dāng)前回溯節(jié)點(diǎn)是題目已經(jīng)標(biāo)記過(guò)的就在往前回溯一步

if(i<0)
{
printf("已經(jīng)找出數(shù)獨(dú)所有解共有:%d個(gè)解!\n",c);
return 1;
}
//嘗試對(duì)上一回溯點(diǎn)進(jìn)行擴(kuò)展
if(!sudu_ji[i])sudu[i]++;
continue;
}
}

return 0;
}

void TuiLi::hh_init()
{
//數(shù)據(jù)初始化
int i,j;
printf("請(qǐng)輸入皇后問(wèn)題的解題規(guī)模:");
scanf("%d",&N);
printf("\n");
for(i=0;i<1024;i++)
{
hh[i]=0;
}
for(i=0;i<30;i++)
for(j=0;j<30;j++)
{
HH[i][j]=0;
}
}

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

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

}

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

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

int TuiLi::ok_hh(int m)
{
int i,j,x,y;
x=0;
for(i=0;i<N;i++)
for(j=0,x=0;j<N;j++)
{
x+=HH[i][j];
if(x>=2) return 1;
}
//不允許行重復(fù)
for(i=0;i<N;i++)
for(j=0,x=0;j<N;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;
}
}
//不允許斜線(xiàn)重復(fù)


return 0;
}

int TuiLi::ok_hh_sc()
{
//最后判斷解是否合法
int i,j,x=0;
for(i=0;i<N;i++)
for(j=0;j<N;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",N,c);
printf("\n如果皇后問(wèn)題解太多的話(huà)就只輸出前面100個(gè)!\n");

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

return 0;
}

關(guān)閉窗口

相關(guān)文章

主站蜘蛛池模板: 午夜精品一区二区三区在线观看 | 亚洲 中文 欧美 日韩 在线观看 | 青青草综合 | 精品国产一区二区三区久久久蜜月 | 中文字幕中文字幕 | 亚洲人成在线观看 | 婷婷中文字幕 | 国产av毛片 | 国产午夜精品视频 | 日韩中文字幕在线视频 | 亚洲成人精品一区 | 天天干天天色 | 免费看国产一级特黄aaaa大片 | 久久国品片 | 成人在线中文字幕 | 九九热最新地址 | 91精品国产综合久久福利软件 | 91一区二区 | 精品国产一区二区国模嫣然 | 成人久久久 | 日韩中文字幕在线观看 | 日韩视频1 | 午夜精品一区 | 欧美黑人又粗大 | 天堂色 | 欧美 日韩 在线播放 | 免费一级大片 | 日韩一区二区三区在线播放 | a久久 | 波多野吉衣在线播放 | 奇米久久久 | 国产97在线看 | 国产激情一区二区三区 | 波多野结衣在线观看一区二区三区 | 玖玖国产精品视频 | 国产精品免费看 | 在线一区视频 | 一区二区在线 | 亚洲精品福利视频 | 天天天天天操 | 日韩欧美一区二区三区 |