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

The Fourth Dimension Space

枯葉北風寒,忽然年以殘,念往昔,語默心酸。二十光陰無一物,韶光賤,寐難安; 不畏形影單,道途阻且慢,哪曲折,如渡飛湍。斬浪劈波酬壯志,同把酒,共言歡! -如夢令

暑假集訓專題訓練1::搜索 行列轉換問題 初識雙向廣搜

從兩個方向分別擴展,效率果然好很多^_^
總算對雙廣有點了解了,再做點題應該就會熟悉了吧
#include<iostream>
#include
<algorithm>
#include
<map>
#include
<queue>
using namespace std;

bool can;
int m,n,ans;


struct KEY
{
    
int a[10];
    
bool operator <(KEY o) const
    
{
        
for(int i=0;i<m;i++
            
if(a[i]!=o.a[i]) return a[i]<o.a[i];
        
return false;
    }

}
;


struct NODE
{
    
int a[10];
    
int step;
}
;

KEY key;
NODE s,t;
map
<KEY,int>Front_Hash,Back_Hash;
map
<KEY,int>::iterator it;
queue
<NODE>Front_Q,Back_Q;


int input(int a[])//讀入一組數據,返回值是這組數據中"1"的個數
{
    
int c;
    
int i,j,num=0;
    
for(i=0;i<m;i++)
    
{
        
for(j=0;j<n;j++)
        
{
            scanf(
"%1d",&c);
            num
+=c;
            a[i]
=(a[i]<<1)+c;
        }

    }

    
return num;
}



//交換一個狀態中第i列和第j列,i從0開始計
void Swap_Two_Row(int a[],int i,int j)
{
    swap(a[i],a[j]);
}


//交換一個狀態中第i列和第j列,i從0開始計,i>j
void Swap_Two_Colum(int a[],int i,int j)
{
    
int k,p=1<<(n-j-1),q=1<<(n-i-1),r=i-j,x,y;
    
for(k=0;k<m;k++)
    
{
        x
=a[k]&p;
        y
=a[k]&q;
        a[k]
=a[k]-x-y+(x>>r)+(y<<r);
    }

}


//反轉一個狀態中的第i行
void Reverse_One_Row(int a[],int i)
{
    
int j,l=n>>1,x,y;
    
for(j=0;j<l;j++)
    
{
        x
=a[i]&(1<<(n-j-1));
        y
=a[i]&(1<<(j));
        a[i]
=a[i]-x-y+(x>>(n-j-j-1))+(y<<(n-j-j-1));
    }

}


//反轉一個狀態中的第i列
void Reverse_One_Colum(int a[],int i)
{
    
short j,l=m>>1,r=1<<(n-i-1),x,y;
    
for(j=0;j<l;j++)
    
{
        x
=a[j]&r;
        y
=a[m-j-1]&r;
        a[j]
=a[j]-x+y;
        a[m
-j-1]=a[m-j-1]-y+x;
    }
        
}


void Insert_Front_Queue(NODE p)
{
    
for(short i=0;i<m;i++)
        key.a[i]
=p.a[i];
    it
=Front_Hash.find(key);
    
if(it!=Front_Hash.end()) 
        
return;
    
//在Front_Q中已經有這個狀態,返回
    Front_Hash[key]=p.step;
    Front_Q.push(p);
    it
=Back_Hash.find(key);
    
if(it!=Back_Hash.end())
    
{
        ans
=(p.step+it->second);//因為兩個方向均滿足BFS的性質,所以搜到的第一個解答即為答案
        can=true;
    }

}



void Insert_Back_Queue(NODE p)
{
    
for(int i=0;i<m;i++)
        key.a[i]
=p.a[i];
    it
=Back_Hash.find(key);
    
if(it!=Back_Hash.end()) 
        
return;
    
//在Back_Q中已經有這個狀態,返回
    Back_Hash[key]=p.step;
    Back_Q.push(p);
    it
=Front_Hash.find(key);
    
if(it!=Front_Hash.end())//插入Back_Q后看看Front_Q中有沒有這個狀態,有就說明搜到了解
    {
        ans
=(it->second+p.step);//搜到的第一個解即為答案
        can=true;
    }

}


bool Equal(int a[],int b[])
{
    
for(short i=0;i<m;i++if(a[i]!=b[i]) return false;
    
return true;
}


void DBFS()//雙向廣搜主過程
{
    NODE Front_last,Front_now;
//從Front_Q隊首拿出的第一個結點,新擴展出來的節點
    NODE Back_last,Back_now;//從Back_Q隊首拿出的第一個結點,新擴展出來的節點
    while(!Front_Q.empty()) Front_Q.pop();
    
while(!Back_Q.empty()) Back_Q.pop();
    Front_Hash.clear();
    Back_Hash.clear();
    
//
    for(short i=0;i<m;i++) key.a[i]=s.a[i];
    Front_Hash[key]
=0;
    Front_Q.push(s);
    
//
    for(short i=0;i<m;i++) key.a[i]=t.a[i];
    Back_Hash[key]
=0;
    Back_Q.push(t);
    
//init
    while(!Front_Q.empty()||!Back_Q.empty())
    
{
        
int step;
        
if(!Front_Q.empty())//擴展正隊列向
        {
            step
=Front_Q.front().step;
            
while(!Front_Q.empty()&&Front_Q.front().step==step)//一次擴展一層,注意這個Front_Q.front().step==step
            {
                Front_last
=Front_Q.front();
                
for(int i=0;i<m;i++)
                
{
                    
for(int j=0;j<i;j++)
                    
{
                        Front_now
=Front_last;
                        Swap_Two_Row(Front_now.a,i,j);
                        Front_now.step
++;    
                        Insert_Front_Queue(Front_now);
                        
if(can) return;
                    }

                    Front_now
=Front_last;
                    Reverse_One_Row(Front_now.a,i);
                    Front_now.step
++;
                    Insert_Front_Queue(Front_now);
                    
if(can) return;
                }

                
for(short i=0;i<n;i++)
                
{
                    
for(short j=0;j<i;j++)
                    
{
                        Front_now
=Front_last;
                        Swap_Two_Colum(Front_now.a,i,j);
                        Front_now.step
++;        
                        Insert_Front_Queue(Front_now);
                        
if(can) return;
                    }

                    Front_now
=Front_last;
                    Reverse_One_Colum(Front_now.a,i);
                    Front_now.step
++;
                    Insert_Front_Queue(Front_now);
                    
if(can) return;
                }

                Front_Q.pop();
                
if(can) return;
            }

        }

        
if(!Back_Q.empty())//擴展反向隊列
        {
            step
=Back_Q.front().step;
            
while(!Back_Q.empty()&&Back_Q.front().step==step)//一層一層擴展
            {
                Back_last
=Back_Q.front();
                
for(short i=0;i<m;i++)
                
{
                    
for(short j=0;j<i;j++)
                    
{
                        Back_now
=Back_last;
                        Swap_Two_Row(Back_now.a,i,j);
                        Back_now.step
++;        
                        Insert_Back_Queue(Back_now);
                        
if(can) return;
                    }

                    Back_now
=Back_last;
                    Reverse_One_Row(Back_now.a,i);
                    Back_now.step
++;
                    Insert_Back_Queue(Back_now);
                    
if(can) return;
                }

                
for(short i=0;i<n;i++)
                
{
                    
for(short j=0;j<i;j++)
                    
{
                        Back_now
=Back_last;
                        Swap_Two_Colum(Back_now.a,i,j);
                        Back_now.step
++;    
                        Insert_Back_Queue(Back_now);
                        
if(can) return;
                    }

                    Back_now
=Back_last;
                    Reverse_One_Colum(Back_now.a,i);
                    Back_now.step
++;
                    Insert_Back_Queue(Back_now);
                    
if(can) return;
                }

                Back_Q.pop();
                
if(can) return;
            }

        }

    }

}


int main()
{
    
while(scanf("%d %d",&m,&n)!=EOF)
    
{
        
for(short i=0;i<m;i++) s.a[i]=t.a[i]=0;
        
int cnt1=0;
        
int cnt2=0;
        cnt1
=input(s.a);
        cnt2
=input(t.a);
        
if(cnt1!=cnt2)
        
{
            printf(
"No solution!\n");
            
continue;
        }

        s.step
=t.step=0;
        
if(Equal(s.a,t.a))
        
{
            puts(
"0");
            
continue;
        }

        can
=false;
        ans
=-1;
        DBFS();
        
if(can) 
            printf(
"%d\n",ans);
        
else
            puts(
"No solution!");
    }

    
return 0;
}





posted on 2010-07-10 22:42 abilitytao 閱讀(520) 評論(1)  編輯 收藏 引用

評論

# re: 暑假集訓專題訓練1::搜索 行列轉換問題 初識雙向廣搜[未登錄] 2011-04-30 21:56 clover

還初識,這么長啊。怎么學  回復  更多評論   


只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲国产婷婷综合在线精品 | 国产日韩欧美日韩| 欧美不卡高清| 欧美日韩精品免费| 国产精品久久久久天堂| 国产精品视频你懂的| 国产精品美女久久久久av超清 | 亚洲欧美文学| 性欧美大战久久久久久久久| 欧美亚洲免费电影| 久久天天躁狠狠躁夜夜爽蜜月| 可以看av的网站久久看| 欧美日韩国产在线播放网站| 亚洲天堂免费观看| 欧美在线观看视频在线| 美女免费视频一区| 欧美三日本三级少妇三2023| 国产午夜精品一区二区三区视频| 伊人色综合久久天天| 日韩亚洲在线观看| 久久一区二区三区四区| 欧美福利一区二区三区| 亚洲精品视频在线看| 性欧美大战久久久久久久久| 欧美高清在线一区| 国产色婷婷国产综合在线理论片a| 亚洲国产精品va在线看黑人动漫 | 午夜精品网站| 欧美大片免费久久精品三p | 亚洲欧美成人一区二区在线电影| 欧美在线看片a免费观看| 欧美国产日韩一区二区在线观看| 国产精品视频最多的网站| 亚洲日本免费电影| 久久久久久欧美| 一区二区三区欧美成人| 久久综合九色综合欧美狠狠| 国产精品久久久久91| 欧美成人激情在线| 国产日韩综合| 午夜精品电影| 亚洲欧洲日本国产| 亚洲欧美日韩综合| 欧美日韩中文| 亚洲欧洲日本专区| 久久精品视频在线| 麻豆精品视频在线| 欧美三级第一页| 亚洲欧洲一区二区三区在线观看 | 久久天天躁狠狠躁夜夜av| 亚洲天堂网站在线观看视频| 欧美激情第二页| 亚洲夫妻自拍| 麻豆精品在线视频| 久久精品99国产精品| 国产欧美一区二区三区久久人妖| 亚洲一区二三| 在线亚洲一区观看| 亚洲午夜一区二区三区| 国产精品hd| 亚洲少妇诱惑| 99精品国产热久久91蜜凸| 欧美日韩国产影片| 一区二区电影免费观看| 亚洲日韩成人| 亚洲自拍偷拍麻豆| 欧美一区二区三区视频免费播放| 日韩西西人体444www| 欧美日韩伦理在线| 亚洲已满18点击进入久久| 一区二区不卡在线视频 午夜欧美不卡'| 欧美高清视频在线播放| 在线视频欧美日韩精品| 这里是久久伊人| 国产精品一区二区在线观看网站 | 亚洲欧美另类国产| 亚洲一区二区三区午夜| 午夜精品福利一区二区蜜股av| 欧美日韩中文在线观看| 午夜精品久久久久久久久久久| 国产精品爱啪在线线免费观看 | 欧美激情第六页| 日韩视频精品在线| 国产综合色在线| 亚洲二区精品| 亚洲精品少妇| 国产日韩在线一区| 亚洲电影免费观看高清完整版在线| 美女性感视频久久久| 99视频热这里只有精品免费| 一区二区三区视频在线| 国产在线视频欧美一区二区三区| 亚洲第一级黄色片| 国产精品免费网站| 亚洲第一福利视频| 国产日本精品| 亚洲三级视频| 国产在线观看一区| 91久久夜色精品国产网站| 国产精品夜夜嗨| 亚洲风情亚aⅴ在线发布| 国产精品久久久久久久久久免费| 久久婷婷久久| 国产精品久久久久久久久免费| 在线观看亚洲视频| 中文精品视频| 亚洲精品久久久久久一区二区| 亚洲一卡久久| 一本色道久久综合| 久久久久久网站| 香蕉久久一区二区不卡无毒影院| 另类综合日韩欧美亚洲| 亚洲日本免费电影| 国产欧美日本在线| 日韩亚洲成人av在线| 在线免费观看日韩欧美| 亚洲一区二区三区免费观看| 亚洲免费观看高清在线观看| 欧美一区二区在线| 午夜老司机精品| 欧美日韩中文字幕在线视频| 欧美成人自拍| 尤妮丝一区二区裸体视频| 亚洲欧美韩国| 午夜在线视频一区二区区别| 欧美日本精品一区二区三区| 欧美国产日韩在线| 在线观看欧美| 久久全国免费视频| 美国成人直播| 在线欧美电影| 99精品热6080yy久久| 午夜国产一区| 亚洲午夜精品久久久久久app| 亚洲国产精品专区久久| 久久全球大尺度高清视频| 老妇喷水一区二区三区| 含羞草久久爱69一区| 久久国产黑丝| 欧美91视频| 亚洲精品麻豆| 欧美乱在线观看| 久久久国产成人精品| 久久精品国产精品亚洲| 国产亚洲二区| 久久精品国产亚洲aⅴ| 久久精品一本| 在线色欧美三级视频| 老鸭窝毛片一区二区三区| 亚洲国产91色在线| 亚洲精品综合精品自拍| 欧美无砖砖区免费| 亚洲欧美乱综合| 麻豆av福利av久久av| 亚洲欧洲一区二区三区久久| 欧美激情综合| 亚洲在线观看免费| 久久夜色精品国产亚洲aⅴ | 激情六月综合| 国产精品国产一区二区| 亚洲午夜久久久久久久久电影网| 午夜在线成人av| 亚洲国产高清aⅴ视频| 欧美精品一区二区三区视频| 99热这里只有精品8| 欧美在线观看www| 亚洲风情亚aⅴ在线发布| 欧美日韩高清在线播放| 亚洲欧美日韩成人| 欧美1区2区3区| 亚洲综合色丁香婷婷六月图片| 国产在线一区二区三区四区| 欧美成人一区在线| 午夜精品久久久久久久99黑人 | 亚洲影音一区| 久久精品电影| 亚洲国产小视频| 国产精品久久999| 久久亚洲欧洲| 亚洲视频精选| 欧美国产先锋| 欧美中文字幕久久| 日韩亚洲在线观看| 狠色狠色综合久久| 欧美日韩xxxxx| 久久国产直播| 亚洲小说春色综合另类电影| 牛牛精品成人免费视频| 亚洲欧美日韩国产综合在线| 亚洲国产一区二区a毛片| 国产欧美日韩视频| 欧美日韩亚洲一区二区三区四区 | 国产精品丝袜白浆摸在线| 猛男gaygay欧美视频| 亚洲一区中文字幕在线观看| 麻豆久久精品| 久久久免费av| 亚洲一区网站| 99人久久精品视频最新地址| 在线看不卡av|