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

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 閱讀(562) 評論(0)  編輯 收藏 引用 所屬分類: AlgorithmUSACO搜索

導航

<2009年7月>
2829301234
567891011
12131415161718
19202122232425
2627282930311
2345678

統計

常用鏈接

留言簿(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>
            欧美日韩一区二区三区高清| 亚洲日本免费| 国产日韩欧美在线一区| 欧美黑人一区二区三区| 毛片精品免费在线观看| 快播亚洲色图| 欧美精品一区视频| 欧美午夜一区二区三区免费大片 | 亚洲国产精品黑人久久久| 免费观看30秒视频久久| 欧美福利一区二区| 亚洲精品乱码久久久久| 亚洲先锋成人| 欧美国产日韩精品| 国产麻豆精品视频| 亚洲激情在线| 欧美一区在线直播| 亚洲高清在线播放| 亚洲欧美变态国产另类| 久久综合福利| 国产日韩欧美综合一区| 亚洲美女视频网| 久久精品人人| 国产一区二区三区免费观看| 红桃视频国产一区| 亚洲伊人伊色伊影伊综合网| 久久综合成人精品亚洲另类欧美| 亚洲美女91| 欧美激情综合在线| 亚洲国产高清自拍| 久久一区国产| 久久久久久亚洲精品中文字幕| 欧美日韩亚洲另类| 一本色道久久加勒比精品| 女人天堂亚洲aⅴ在线观看| 亚洲女爱视频在线| 国产欧美精品一区| 亚洲欧美日韩国产综合| 亚洲深夜福利网站| 欧美日韩一区二区视频在线观看| 亚洲国产精品热久久| 免费影视亚洲| 欧美电影电视剧在线观看| 亚洲欧洲在线一区| 亚洲精品一区在线观看| 欧美午夜三级| 久久婷婷丁香| 欧美男人的天堂| 亚洲中午字幕| 久久综合色播五月| 亚洲精品资源| 欧美一区二区大片| 日韩一级二级三级| 亚洲欧美日韩精品久久亚洲区| 国产婷婷色一区二区三区在线| 久久影音先锋| 国产精品美女999| 欧美成人精品高清在线播放| 99国产精品| 激情五月综合色婷婷一区二区| 久久久久中文| 夜色激情一区二区| 欧美国产日产韩国视频| 香蕉亚洲视频| 亚洲一区二区免费看| 亚洲二区在线视频| 国语自产精品视频在线看抢先版结局 | 亚洲一区在线播放| 在线观看成人av电影| 国产农村妇女毛片精品久久莱园子 | 99这里只有精品| 亚洲国产一区二区三区在线播| 欧美一区二区三区在| 亚洲午夜av在线| 在线视频你懂得一区二区三区| 亚洲激情在线视频| 日韩网站在线观看| 亚洲激情成人网| 91久久亚洲| 亚洲你懂的在线视频| 欧美在线播放一区| 久久蜜桃av一区精品变态类天堂| 午夜精品电影| 久久综合网色—综合色88| 久久嫩草精品久久久精品| 欧美成人午夜视频| 亚洲人成人77777线观看| 亚洲精选成人| 欧美一级艳片视频免费观看| 欧美亚洲在线播放| 免费看精品久久片| 日韩亚洲欧美成人| 香蕉免费一区二区三区在线观看 | 99成人在线| 午夜久久影院| 欧美激情视频一区二区三区在线播放 | 亚洲人在线视频| 亚洲一级二级| 欧美精品久久久久久久免费观看| 欧美色欧美亚洲高清在线视频| 国产午夜精品视频免费不卡69堂| 在线播放国产一区中文字幕剧情欧美 | 久久精品国亚洲| 欧美国产视频日韩| 午夜在线观看免费一区| 欧美国产丝袜视频| 精品成人国产在线观看男人呻吟| 中国亚洲黄色| 亚洲免费观看在线视频| 免费亚洲电影| 1769国产精品| 欧美成人精品h版在线观看| 久久国产精品72免费观看| 国产精品www994| 亚洲欧洲99久久| 亚洲性人人天天夜夜摸| 欧美日韩一区免费| 亚洲一区二区欧美日韩| 夜夜嗨av一区二区三区四季av| 欧美好骚综合网| 欧美大片在线看免费观看| 亚洲第一在线综合网站| 麻豆精品在线观看| 玖玖玖国产精品| 亚洲精品一区在线| 一区二区精品在线| 国产日韩欧美a| 欧美电影在线观看完整版| 欧美激情亚洲综合一区| 亚洲性人人天天夜夜摸| 欧美精品videossex性护士| 在线观看视频一区| 欧美激情小视频| 国产精品乱人伦一区二区| 午夜精品一区二区三区在线播放| 香蕉成人久久| 一区二区冒白浆视频| 欧美一区国产一区| 日韩午夜在线观看视频| 亚洲亚洲精品三区日韩精品在线视频| 国产麻豆精品久久一二三| 欧美国产三级| 狠狠色综合日日| 日韩一二在线观看| 在线成人小视频| 亚洲尤物在线视频观看| 亚洲精品亚洲人成人网| 亚洲免费视频网站| 99国内精品| 欧美激情2020午夜免费观看| 久久久精品tv| 国产亚洲成人一区| 亚洲一区三区视频在线观看| 一片黄亚洲嫩模| 欧美精品成人一区二区在线观看| 久久精品电影| 国产日韩av高清| 亚洲一区二区三区激情| 亚洲一区二区三区高清不卡| 欧美精品电影| 一区二区三区欧美亚洲| 亚洲性av在线| 国产欧美精品在线播放| 香蕉成人啪国产精品视频综合网| 中文久久精品| 国产欧美短视频| 久久久青草婷婷精品综合日韩 | 欧美极品在线播放| 最新亚洲电影| 中文精品视频| 国产一区二区在线免费观看| 欧美一区国产在线| 欧美第十八页| 亚洲一区在线直播| 国产亚洲电影| 免费短视频成人日韩| av成人天堂| 美女999久久久精品视频| 91久久在线| 激情欧美日韩| 欧美视频一区二| 久久精品国产99| av成人福利| 欧美二区不卡| 欧美一区二区视频观看视频| 亚洲国产精品va在线看黑人动漫| 欧美交受高潮1| 久久人91精品久久久久久不卡| 亚洲精品裸体| 亚洲福利视频二区| 久久久久一区二区三区| 亚洲午夜激情在线| 亚洲成色精品| 国产三级欧美三级| 国产精品白丝av嫩草影院| 牛牛影视久久网| 免费成人在线观看视频| 久久九九热免费视频| 欧美一级网站| 久久精品国产视频|