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

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 | 一区二区三区欧美激情| 欧美国产精品va在线观看| 夜夜嗨av一区二区三区网页| 亚洲视频在线视频| 亚洲电影av在线| 这里只有精品视频| 亚洲国产一区在线观看| 亚洲性线免费观看视频成熟| 亚洲国产欧美在线| 亚洲欧美制服另类日韩| 亚洲精品日韩综合观看成人91| 亚洲一区二区三区在线观看视频| 在线国产精品播放| 亚洲一区二区三区涩| 亚洲人成在线影院| 欧美在线播放一区二区| 国产精品99久久久久久有的能看| 欧美在线播放一区| 久久日韩精品| 欧美日韩午夜| 久久尤物电影视频在线观看| 欧美日韩一区二区免费视频| 欧美jizzhd精品欧美巨大免费| 国产精品久久久一本精品| 欧美激情精品久久久久久蜜臀| 国产精品综合网站| 夜夜爽www精品| 亚洲日本成人| 久久久免费精品视频| 午夜精品影院在线观看| 欧美全黄视频| 亚洲国产欧美在线人成| 国产精品久久久久免费a∨| 亚洲人屁股眼子交8| 亚洲区免费影片| 久久免费视频在线观看| 久久精品99国产精品酒店日本| 国产精品久久久久7777婷婷| 99re8这里有精品热视频免费 | 午夜国产精品视频| 亚洲欧美国产制服动漫| 欧美日韩综合| 一本久道久久久| 一区二区三区欧美在线观看| 榴莲视频成人在线观看| 美女视频一区免费观看| 黄色成人在线网址| 久久久久久网址| 美女尤物久久精品| 在线观看欧美| 久久久欧美一区二区| 欧美成年人网| 亚洲片区在线| 欧美片在线播放| 日韩手机在线导航| 亚洲在线一区二区三区| 国产精品视频精品视频| 香蕉久久夜色精品国产| 麻豆精品网站| 亚洲国产精品va| 欧美经典一区二区三区| 99亚洲精品| 欧美影片第一页| 国产综合色一区二区三区| 久久久精品国产免大香伊| 蘑菇福利视频一区播放| 亚洲精品久久久久久久久久久久 | 亚洲国产精品成人va在线观看| 亚洲国产午夜| 欧美日韩你懂的| 亚洲尤物视频在线| 久久综合网hezyo| 亚洲人体1000| 国产精品日韩欧美一区| 久久aⅴ国产欧美74aaa| 欧美激情国产日韩精品一区18| 日韩视频精品在线观看| 国产精品porn| 久久久精品日韩欧美| 亚洲区第一页| 久久gogo国模裸体人体| 亚洲国产日韩欧美在线99| 欧美日韩一区二区三区在线看 | 国内精品久久国产| 麻豆精品国产91久久久久久| 亚洲黑丝在线| 欧美亚洲成人网| 欧美一区2区视频在线观看| 欧美成人自拍视频| 性18欧美另类| 91久久嫩草影院一区二区| 国产精品久久久99| 免费欧美电影| 性做久久久久久久免费看| 亚洲第一区在线| 欧美亚洲在线播放| 亚洲精选一区| 国产有码在线一区二区视频| 欧美精品三区| 久久久久久久久综合| 在线亚洲欧美专区二区| 亚洲第一免费播放区| 久久久久国产精品一区二区| 一区二区高清视频| 亚洲国产精品一区二区www在线| 国产精品日韩高清| 欧美日韩一区二区三区视频| 久久久久久91香蕉国产| 一区二区成人精品 | 国产视频自拍一区| 欧美日韩国产精品成人| 免费高清在线视频一区·| 午夜欧美精品| 中文日韩在线| 亚洲精品免费一二三区| 欧美福利电影在线观看| 久久蜜桃香蕉精品一区二区三区| 亚洲影院高清在线| 亚洲一区二区网站| 夜夜嗨av色综合久久久综合网| 亚洲电影毛片| 在线不卡免费欧美| 国模私拍视频一区| 国产欧美日韩免费看aⅴ视频| 欧美日韩一区二区三区免费看| 欧美激情精品久久久久久蜜臀 | 久久精品视频一| 午夜视频久久久久久| 亚洲一区二区少妇| 在线视频免费在线观看一区二区| 91久久国产精品91久久性色| 狠狠色狠狠色综合人人| 国产一级揄自揄精品视频| 国产日本亚洲高清| 国产拍揄自揄精品视频麻豆| 国产精品日韩| 国产日韩欧美麻豆| 国产亚洲视频在线观看| 国产一区二区按摩在线观看| 国产一区二区三区免费在线观看| 国产日韩亚洲欧美| 国模 一区 二区 三区| 在线观看视频亚洲| 亚洲黄色大片| 日韩视频免费看| 一区二区三欧美| 亚洲免费网站| 久久成人精品一区二区三区| 久久精品最新地址| 免费久久99精品国产| 欧美高清在线播放| 亚洲二区免费| 夜夜爽99久久国产综合精品女不卡| 91久久精品国产91久久| 一区二区福利| 激情成人综合网| 在线成人欧美| 亚洲精品在线免费观看视频| 99v久久综合狠狠综合久久| 亚洲免费观看高清完整版在线观看熊| 亚洲精品视频免费在线观看| 99国内精品久久| 亚洲欧美日韩国产综合| 久久九九国产精品怡红院| 美女尤物久久精品| 日韩亚洲国产欧美| 亚洲欧美日韩另类| 久久免费视频网站| 欧美系列电影免费观看| 国产综合婷婷| 日韩一区二区精品| 欧美一区国产在线| 亚洲大片免费看| 亚洲欧美日韩综合一区| 免费日韩成人| 国产欧美一区二区三区久久| 亚洲国产精品美女| 欧美在线观看日本一区| 亚洲风情在线资源站| 亚洲午夜精品17c| 久久综合一区二区| 国产精品盗摄久久久| 在线观看视频亚洲| 欧美一区二区三区免费大片| 亚洲国产电影| 欧美伊人精品成人久久综合97 | 欧美国产欧美亚洲国产日韩mv天天看完整 | 久久久精品五月天| 欧美日韩一区不卡| 尤物99国产成人精品视频| 中文一区字幕| 免费一级欧美在线大片| 亚洲一区制服诱惑| 欧美精品亚洲二区| 在线日韩av| 久久精品一级爱片| 亚洲天堂第二页| 欧美日韩国产123区| 亚洲国产精品成人久久综合一区|