青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

USACO 3.2 Magic Squares

?BFS搜索題。代碼寫的比較亂,用一個set來存儲已經訪問過的結點。analysis中的標程有不少可以學習的地方,如幾個操作的變換,用轉換數組來寫,代碼清晰明了,encode方法就省去了set。我通過保存整個樹來輸出解,標程通過反向操作,來輸出解,做法很巧妙。

#include?<iostream>
#include?
<fstream>
#include?
<set>
#include?
<queue>

using?namespace?std;

ifstream?fin(
"msquare.in");
ofstream?fout(
"msquare.out");

#ifdef?_DEBUG
#define?out?cout
#define?in?cin
#else
#define?out?fout
#define?in?fin
#endif

int?final[8];
set<int>visited;
char?result[8*7*6*5*4*3*2*1+1];

struct?queue_node{
????
int?current[8];
????queue_node?
*parent;
????
char?op;
};

void?op(int?*current,char?c)
{
????
int?tmp;
????
switch(c){
????????
case?'A':
????????????
for(int?i=0;i<4;++i)
????????????????swap(current[i],current[
7-i]);
????????????
break;
????????
case?'B':
????????????tmp?
=?current[3];
????????????
for(int?i=3;i>=1;--i)
????????????????current[i]?
=?current[i-1];
????????????current[
0]?=?tmp;
????????????tmp?
=?current[4];
????????????
for(int?i=4;i<=6;++i)
????????????????current[i]?
=?current[i+1];
????????????current[
7]?=?tmp;
????????????
break;
????????
case?'C':
????????????tmp?
=?current[6];
????????????current[
6]?=?current[5];
????????????current[
5]?=?current[2];
????????????current[
2]?=?current[1];
????????????current[
1]?=?tmp;
????????????
break;
????}
}

int?cur_value(int?*cur)
{
????
int?res?=?0;
????
for(int?i=0;i<8;++i){
????????res
*=10;
????????res
+=cur[i];
????}

????
return?res;
}


void?solve()
{
????
for(int?i=0;i<8;++i){
????????
in>>final[i];
????}

????queue
<queue_node*>?q;
????queue_node?
*node?=?new?queue_node;
????
for(int?i=0;i<8;++i)
????????node
->current[i]?=?i+1;

????node
->parent?=?NULL;

????q.push(node);

????
while(?!q.empty()?){
????????queue_node?
*node?=?q.front();
????????q.pop();

????????
int?cur?=?cur_value(node->current);
????????
if(?visited.find(?cur)?!=?visited.end())
????????????
continue;
????????visited.insert(cur);

????????
bool?ok?=?true;
????????
for(int?i=0;i<8;++i){
????????????
if(node->current[i]!=final[i]){
????????????????ok?
=?false;
????????????????
break;
????????????}
????????}

????????
if(ok){
????????????
int?i?=?0;
????????????
while(node->parent!=NULL){
????????????????result[i
++]?=?node->op;
????????????????node
=node->parent;
????????????}

????????????
if(i==0){
????????????????
out<<0<<endl<<endl;
????????????????exit(
0);
????????????}

????????????
out<<i<<endl;

????????????
int?j;
????????????i
--;
????????????
for(j=0;i>=0;i--,j++){
????????????????
out<<result[i];
????????????????
if(j%60==59)?out<<endl;
????????????}
????????????
????????????
if(j%60!=0)
????????????????
out<<endl;

????????????exit(
0);
????????}

????????
for(char?c='A';c<='C';++c){
????????????queue_node?
*?n?=?new?queue_node;
????????????memcpy(n
->current,node->current,sizeof(node->current));
????????????op(n
->current,c);
????????????n
->op?=?c;
????????????n
->parent?=?node;
????????????q.push(n);
????????}
????}
}

int?main(int?argc,char?*argv[])
{
????solve();?
????
return?0;
}


posted on 2009-07-06 20:01 YZY 閱讀(568) 評論(0)  編輯 收藏 引用 所屬分類: AlgorithmUSACO搜索

導航

<2009年6月>
31123456
78910111213
14151617181920
21222324252627
2829301234
567891011

統計

常用鏈接

留言簿(2)

隨筆分類

隨筆檔案

搜索

積分與排名

最新評論

閱讀排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            欧美在线www| 久久男人av资源网站| 91久久久久| 麻豆视频一区二区| 亚洲黄页一区| 日韩视频一区二区三区在线播放免费观看 | 亚洲丝袜av一区| 日韩视频在线观看| 国产精品一区二区久久| 狼狼综合久久久久综合网| 久久天堂av综合合色| 亚洲片在线观看| 99精品国产高清一区二区| 欧美日韩裸体免费视频| 午夜久久久久久| 欧美在线网址| 亚洲精品乱码久久久久| 中文网丁香综合网| 亚洲电影欧美电影有声小说| 亚洲激情社区| 国产亚洲精品一区二555| 欧美成人精品在线| 欧美性生交xxxxx久久久| 久久噜噜亚洲综合| 欧美日韩美女在线| 久久网站热最新地址| 欧美日韩小视频| 久久午夜精品一区二区| 欧美—级高清免费播放| 久久精品观看| 欧美深夜福利| 欧美高清在线一区二区| 国产精品影视天天线| 亚洲国产日韩欧美在线图片| 国产麻豆日韩| 亚洲精品女人| 国产一区二区三区在线免费观看| 久久精品水蜜桃av综合天堂| 欧美日韩成人一区二区| 久久亚洲欧美| 国产欧美韩国高清| 99re这里只有精品6| 亚洲国产精品ⅴa在线观看| 亚洲欧美日韩一区在线| 中国成人黄色视屏| 欧美高清免费| 美女久久一区| 国产中文一区| 亚洲一区二区高清| 一区二区三区三区在线| 欧美激情久久久| 欧美高清一区二区| 精品动漫av| 欧美在线观看视频一区二区| 亚洲免费视频一区二区| 欧美裸体一区二区三区| 欧美激情一区三区| 亚洲成色www久久网站| 欧美一级片在线播放| 午夜激情一区| 国产精品视频一区二区三区| 99v久久综合狠狠综合久久| 99精品欧美一区二区蜜桃免费| 亚洲综合大片69999| 午夜精品福利一区二区蜜股av| 欧美精品18+| 91久久精品一区二区别| 99riav久久精品riav| 欧美激情视频一区二区三区在线播放 | 亚洲成色777777在线观看影院| 亚洲精品小视频在线观看| **性色生活片久久毛片| 久久久久九九九九| 美日韩在线观看| 亚洲国产裸拍裸体视频在线观看乱了中文| 亚洲午夜电影| 午夜精品视频| 国产一区亚洲一区| 久久综合九色综合久99| 亚洲大片在线| 一级成人国产| 国产精品一区一区三区| 欧美一区二区三区视频在线 | 永久免费毛片在线播放不卡| 久久久久成人网| 亚洲福利专区| 亚洲午夜av在线| 国产精品嫩草99a| 久久av二区| 亚洲激情欧美| 午夜亚洲精品| 在线播放中文一区| 欧美另类高清视频在线| 亚洲一区国产| 另类尿喷潮videofree| 亚洲国产视频直播| 国产精品大全| 巨胸喷奶水www久久久免费动漫| 欧美不卡视频一区| 亚洲在线黄色| 在线观看一区视频| 欧美日韩一区二区三区在线视频 | 久久精品国产v日韩v亚洲| 在线观看91精品国产入口| 欧美激情小视频| 午夜精彩视频在线观看不卡 | 9人人澡人人爽人人精品| 国产久一道中文一区| 葵司免费一区二区三区四区五区| 欧美激情视频网站| 亚洲欧美综合| 亚洲精品美女| 黑人极品videos精品欧美裸| 欧美日韩一区二区精品| 久久精品一区二区三区中文字幕 | 久久青青草原一区二区| 亚洲视频你懂的| **欧美日韩vr在线| 国产女主播视频一区二区| 欧美精品久久一区| 久久久噜噜噜久久| 亚洲欧美国产日韩中文字幕| 亚洲人成77777在线观看网| 久久久免费精品| 午夜激情综合网| 在线午夜精品| 亚洲精品欧美精品| 亚洲国产精品一区二区第一页| 国产精品二区影院| 欧美日韩国产一区二区| 欧美成人免费小视频| 久久在线免费观看视频| 欧美在线观看视频| 午夜激情综合网| 亚洲性夜色噜噜噜7777| 99re66热这里只有精品4| 亚洲欧洲精品一区| 亚洲第一网站免费视频| 美玉足脚交一区二区三区图片| 欧美一区二区视频在线观看2020 | 国产精品女主播一区二区三区| 蜜桃伊人久久| 麻豆精品91| 免费人成网站在线观看欧美高清| 欧美亚洲尤物久久| 欧美专区在线观看| 久久久久一区二区三区四区| 欧美在线三级| 久久精品理论片| 久久影院午夜论| 女人香蕉久久**毛片精品| 久久躁狠狠躁夜夜爽| 欧美成人免费全部| 99国产精品久久久久久久久久| 亚洲免费视频在线观看| 日韩香蕉视频| 日韩亚洲在线观看| 日韩系列欧美系列| 亚洲午夜极品| 翔田千里一区二区| 久久大综合网| 麻豆成人小视频| 91久久夜色精品国产九色| 亚洲国产天堂久久综合网| 亚洲欧洲日韩综合二区| 在线视频欧美日韩| 欧美一区二区三区在线视频 | 亚洲欧美三级伦理| 亚洲欧洲一区二区三区在线观看| 美女国内精品自产拍在线播放| 久久成人免费网| 欧美电影免费| 亚洲美女视频网| 欧美一级片一区| 欧美顶级少妇做爰| 欧美日韩在线播放| 国产综合色精品一区二区三区| 在线成人激情视频| 一区二区三区色| 久久免费视频在线| 亚洲精品一区在线| 欧美一区二区三区免费观看视频 | 亚洲午夜精品在线| 久久精品综合| 欧美日韩国产在线播放| 国产一区二区三区高清| 99视频一区| 六月天综合网| 亚洲一区二区日本| 蜜臀久久久99精品久久久久久| 欧美三级网址| 亚洲国产精品热久久| 翔田千里一区二区| 91久久国产综合久久91精品网站| 亚洲午夜女主播在线直播| 玖玖玖免费嫩草在线影院一区| 欧美亚州一区二区三区| 亚洲激情亚洲| 久久综合一区| 日韩午夜中文字幕|