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

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>
            一本大道久久a久久精二百| 久久九九精品| 欧美日韩国产欧美日美国产精品| 午夜亚洲福利在线老司机| 99精品久久免费看蜜臀剧情介绍| 欧美成人免费视频| 亚洲成色777777女色窝| 欧美ed2k| 91久久夜色精品国产九色| 欧美激情综合色| 一本色道久久综合精品竹菊 | 国产精品外国| 韩国精品一区二区三区| 亚洲精品国产欧美| 欧美一级网站| 日韩亚洲综合在线| 久久久久久尹人网香蕉| 欧美日韩在线观看一区二区三区| 国产日韩精品视频一区二区三区| 在线播放日韩欧美| 久久久久久久久久码影片| 亚洲精品久久久久久久久久久久 | 亚洲精选国产| 伊人激情综合| 久久er99精品| 99国产精品视频免费观看一公开| 99精品久久久| 欧美日本一道本在线视频| 狠狠久久婷婷| 久久成人资源| 最新国产の精品合集bt伙计| 欧美激情va永久在线播放| 最新高清无码专区| 久久午夜电影网| 国产在线高清精品| 亚洲欧美不卡| 欧美综合国产| 亚洲福利视频一区二区| 亚洲视频播放| 亚洲人成网站777色婷婷| 亚洲一区二区三区影院| 欧美国产日韩一区| 欧美成人精品| 99国产精品视频免费观看一公开| 亚洲电影免费观看高清| 性欧美1819sex性高清| 欧美国产日韩精品| 午夜精品视频在线观看| 国产一区视频在线观看免费| 日韩一级在线| 亚洲在线日韩| 最新日韩精品| 亚洲毛片播放| 合欧美一区二区三区| 亚洲第一偷拍| 国产伦一区二区三区色一情| 久久亚洲欧美| 欧美日韩一区二区三区四区五区| 久久久久久久高潮| 国产精品久久久久久亚洲调教| 欧美电影免费观看高清完整版| 欧美日韩四区| 免费观看成人www动漫视频| 欧美三级资源在线| 亚洲人线精品午夜| 在线欧美一区| 欧美一区国产一区| 久久国产手机看片| 国产美女精品| 亚洲欧美另类国产| 在线视频精品一区| 欧美寡妇偷汉性猛交| 亚洲福利av| 夜夜嗨av一区二区三区免费区| 久久亚洲影院| 亚洲国产小视频在线观看| 欧美午夜大胆人体| 亚洲精品中文字幕女同| 亚洲免费观看高清在线观看 | 中文一区二区| 欧美日韩精品一本二本三本| 亚洲激情社区| 亚洲欧美中文另类| 国产日韩欧美成人| 老司机aⅴ在线精品导航| 蜜臀av国产精品久久久久| 欧美一级久久久| 欧美在线视频在线播放完整版免费观看| 欧美日韩亚洲一区在线观看| 亚洲影视综合| 欧美成人高清| 亚洲欧美福利一区二区| 在线成人av.com| 国产精品国产三级国产普通话99| 亚洲午夜在线观看| 老司机午夜精品视频在线观看| 黄色另类av| 欧美色欧美亚洲高清在线视频| 久久福利毛片| 亚洲欧美综合精品久久成人| 亚洲国产天堂久久综合网| 久久久亚洲欧洲日产国码αv| 妖精成人www高清在线观看| 永久域名在线精品| 国产乱子伦一区二区三区国色天香| 欧美成人三级在线| 久久伊人亚洲| 久久精品日韩欧美| 久久国产精品久久精品国产| 一区二区久久久久久| 欧美激情一区二区三区不卡| 欧美成人第一页| 欧美成人精品一区| 久久成人亚洲| 久久网站热最新地址| 中文在线一区| 亚洲最新在线| 正在播放欧美视频| 亚洲制服av| 久久久久久久97| 亚洲大片免费看| 亚洲欧洲日本一区二区三区| 91久久国产综合久久| 国产精品久久久久一区二区三区共 | 亚洲图色在线| 久久精品国产成人| 欧美成人免费在线视频| 亚洲成色精品| 亚洲午夜性刺激影院| 久久夜精品va视频免费观看| 欧美极品欧美精品欧美视频| 国产欧美亚洲一区| 99在线精品免费视频九九视| 久久高清免费观看| 亚洲最新视频在线播放| 久久久久久电影| 国产情人节一区| 宅男精品导航| 99亚洲一区二区| 欧美激情中文字幕一区二区| 在线观看视频一区| 欧美一区二区女人| 一本色道久久综合| 欧美日韩另类视频| 亚洲天堂av综合网| 宅男噜噜噜66一区二区| 欧美国产激情| 亚洲精品中文字幕女同| 欧美成人午夜剧场免费观看| 麻豆成人在线观看| 91久久国产综合久久蜜月精品| 久久在线免费| 欧美一区二粉嫩精品国产一线天| 国产精品qvod| 亚洲一区二区精品视频| 欧美激情在线| 国产精品a久久久久久| 亚洲少妇在线| 亚洲欧洲日本在线| 欧美日本簧片| 亚洲无毛电影| 性久久久久久久| 1024成人| 亚洲成人在线视频播放| 欧美三级在线| 久久久www| 欧美激情视频一区二区三区在线播放 | 欧美一级在线播放| 亚洲破处大片| 亚洲在线黄色| 99国产精品久久久久久久| 欧美激情在线有限公司| 欧美日韩国产bt| 久久午夜激情| 欧美日韩另类丝袜其他| 老**午夜毛片一区二区三区| 久久综合九色综合欧美狠狠| 亚洲免费影视第一页| 久久福利电影| 亚洲男人的天堂在线观看| 久久精品国产一区二区三| 欧美电影电视剧在线观看| 国产精品hd| 日韩一区二区免费高清| 亚洲福利视频网站| 久久久欧美精品| 欧美在线|欧美| 国产精品看片资源| 亚洲福利视频网| 亚洲国产精品美女| 午夜激情亚洲| 激情成人av| 最新热久久免费视频| 在线免费日韩片| 久久精品中文字幕免费mv| 欧美亚洲一区二区在线| 久久久久久高潮国产精品视| 欧美一区2区三区4区公司二百| 欧美另类变人与禽xxxxx| 日韩视频第一页|