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

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>
            麻豆精品在线观看| 亚洲国产日韩在线| 国产精品嫩草影院一区二区| 久久成人免费网| 亚洲精品日韩久久| 美乳少妇欧美精品| 久久理论片午夜琪琪电影网| 亚洲伊人伊色伊影伊综合网| 亚洲欧洲在线观看| 亚洲娇小video精品| 永久555www成人免费| 国产欧美一区二区三区沐欲| 国产精品二区二区三区| 欧美日韩国产综合一区二区| 欧美激情中文字幕在线| 欧美成人免费播放| 欧美黄在线观看| 欧美日韩国产经典色站一区二区三区| 久久中文字幕一区| 中文av一区特黄| 亚洲一二三级电影| 亚洲免费影院| 久久福利毛片| 欧美aⅴ99久久黑人专区| 蜜臀久久99精品久久久久久9| 亚洲精品国产拍免费91在线| 99精品视频网| 亚洲欧美日韩国产另类专区| 久久av免费一区| 狼人社综合社区| 亚洲黄色有码视频| 91久久精品www人人做人人爽| 亚洲精品一区二区三区樱花| 亚洲视频在线免费观看| 欧美一区二区三区免费观看视频 | 亚洲第一天堂无码专区| 欧美视频导航| 国产精品夜夜夜一区二区三区尤| 国产精品一区二区三区乱码| 在线成人性视频| 一区二区三欧美| 欧美一级一区| 亚洲免费在线视频一区 二区| 久久精品国产成人| 欧美国产三区| 亚洲在线免费视频| 午夜日韩福利| 欧美精品黄色| 好看的亚洲午夜视频在线| 亚洲毛片av| 久久精品网址| 亚洲免费不卡| 久久精品日韩| 亚洲精品之草原avav久久| 亚洲综合日韩中文字幕v在线| 亚洲一区在线视频| 另类天堂视频在线观看| 国产精品久线观看视频| 最新精品在线| 麻豆精品视频在线观看| 亚洲欧美第一页| 欧美国产三区| 国产精品久久| 亚洲欧洲美洲综合色网| 久久久精彩视频| 一区二区三区高清| 欧美激情综合色| 99热免费精品在线观看| 免费在线观看一区二区| 国产欧美日韩在线| 亚洲一区二区三区免费视频| 欧美国产专区| 欧美伊人久久久久久午夜久久久久| 欧美日韩91| 国产欧美在线播放| 亚洲国产精品成人综合色在线婷婷| 欧美影院久久久| 亚洲尤物在线视频观看| 欧美日韩中文字幕在线| 日韩一区二区电影网| 欧美大色视频| 久久综合久久久| 亚洲国产精品久久久久婷婷884 | 日韩一级在线| 欧美激情偷拍| 日韩一区二区免费看| 亚洲国产成人高清精品| 中国av一区| 亚洲永久精品大片| 亚洲第一久久影院| 亚洲最新中文字幕| 国内自拍亚洲| 日韩午夜视频在线观看| 国产亚洲综合精品| 亚洲欧洲久久| 国产日韩综合一区二区性色av| 蜜桃av一区二区| 欧美日韩一区二区精品| 久久久久久国产精品一区| 欧美日本视频在线| 久久中文欧美| 国产欧美日韩精品丝袜高跟鞋 | 欧美一区二区三区婷婷月色| 久久久久久高潮国产精品视| 亚洲一级在线观看| 免费在线播放第一区高清av| 欧美一区二区三区在线| 欧美成人国产| 久久青青草综合| 国产精品免费观看在线| 91久久亚洲| 在线观看亚洲| 欧美一区二区三区久久精品| 亚洲一区精品电影| 欧美精品在线观看91| 噜噜噜91成人网| 国产精品黄色| 99国产精品视频免费观看一公开| 伊人久久大香线| 亚洲欧美日本另类| 亚洲欧美在线免费| 欧美日本一道本在线视频| 欧美成年人在线观看| 国产一区999| 午夜精品福利视频| 欧美一区二区三区免费看 | 国产精品看片资源| 亚洲精品少妇| 亚洲美女中出| 欧美激情欧美激情在线五月| 欧美成人精品一区二区| 国内揄拍国内精品久久| 午夜在线一区| 久久精品国产99国产精品澳门| 国产精品爽黄69| 亚洲色图在线视频| 亚洲欧美精品伊人久久| 欧美三级视频在线| 一本到高清视频免费精品| 中文欧美字幕免费| 欧美日韩中文字幕综合视频| 一二三区精品福利视频| 亚洲伊人伊色伊影伊综合网 | 国产欧美日韩在线观看| 亚洲视频免费看| 久久爱www久久做| 国产欧美在线观看一区| 久久精品国产精品亚洲精品| 欧美三区视频| 欧美一区二区视频在线| 欧美一乱一性一交一视频| 亚洲视频1区| 亚洲视频欧美视频| 性欧美激情精品| 久久国内精品自在自线400部| 性欧美激情精品| 欧美激情亚洲自拍| 欧美日韩hd| 欧美日韩蜜桃| 99re热精品| 欧美日韩综合视频网址| av不卡在线| 欧美在线看片a免费观看| 国产麻豆日韩| 玖玖综合伊人| 中国av一区| 久久xxxx| 亚洲美女电影在线| 国产精品久久久久久久电影 | 99re亚洲国产精品| 国产精品久久网| 久久er99精品| 亚洲精品久久久久中文字幕欢迎你| 日韩视频一区二区| 国产精品爽黄69| 欧美成人按摩| 亚洲欧美日韩精品| 欧美激情91| 久久国产精品一区二区三区四区| 亚洲高清久久网| 国产精品美女久久久免费| 久久永久免费| 午夜精品福利视频| 日韩亚洲一区在线播放| 久久一区精品| 午夜精彩视频在线观看不卡 | 毛片精品免费在线观看| 亚洲天天影视| 91久久在线播放| 免费成人毛片| 欧美在线一二三四区| 亚洲视屏在线播放| 亚洲人www| 伊人精品久久久久7777| 国产亚洲精品久久久久久| 欧美色一级片| 欧美经典一区二区| 麻豆成人在线播放| 久久久五月婷婷| 欧美在线综合|