• <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>

            巢穴

            about:blank

            P2965

               位運算+bfs
               本來用iterator來做隊列的指針,但是莫名其妙的錯誤..
               于是用了int來做指針..安心啊.
              
            #include <iostream>
            #include 
            <vector>
            using namespace std;
            bool hash[65536];

            vector
            <int> answer;
            int fstate[16]={
            0xF888,0xF444,0xF222,0xF111,
            0x8F88,0x4F44,0x2F22,0x1F11,
            0x88F8,0x44F4,0x22F2,0x11F1,
            0x888F,0x444F,0x222F,0x111F}
            ;



            struct state
            {
             
            int value;
             
            int change;
             
            int father;
             
            }
            ;

            vector
            <state> list;
            void jude(int v)
            {
                 
            if (v==0)
                 
            {
                  
            int iter=list.size()-1;
                  
                  
            while(iter!=0)
                  
            {
                      answer.push_back(list.at(iter).change);
                      iter
            =list.at(iter).father;
                  }

                  cout
            <<answer.size()<<endl;
                  
            for (int i=answer.size()-1;i>=0;--i)
                  
            {
                      cout
            <<answer.at(i)/4+1<<" "<<answer.at(i)%4+1<<endl;
                  }

                  
            int cc;cin>>cc;
                  exit(
            0);
                 }

            }

            void init()
            {
                 
            int x=0,u=1;
                 
            for (int i=0;i<4;i++)
                     
            for (int j=0;j<4;j++)
                     
            {
                         
            char ch;
                         cin
            >>ch;
                         
            int k;
                         
            switch(ch)
                         
            {
                           
            case '-':k=0;break;
                           
            case '+':k=1;break;
                           
            default:break;
                         }

                         x
            =x*2+k;
                     }

                

                 hash[x]
            =true;
                 state st;
                 st.value
            =x;
                 st.change
            =-1;
                 st.father
            =0;
                 list.push_back(st);
                
                 jude(x);
                 
            }

            void bfs()
            {
                 vector
            <state>::iterator iter=list.begin();
                 
            int left=0;
                  
                 
                 
            while (left<list.size())
                 
            {
                       state st
            =list.at(left);
                       
            int value=st.value;

                       
            for (int i=0;i<16;i++)
                       
            {
                           
                        
            int n=fstate[i]^value;
                        
                        
            if (hash[n]) continue;

                        state sta;
                        sta.value
            =n;
                        sta.father
            =left;
                        sta.change
            =i;
                        hash[n]
            =true;
                        list.push_back(sta);
                        jude(n);
                       }

                       left
            ++;
                       
                 }

            }

            int main()
            {
                init();
                bfs();
                
            return 0;
            }

            posted on 2009-10-01 16:13 Vincent 閱讀(125) 評論(0)  編輯 收藏 引用 所屬分類: 數據結構與算法

            精品久久久久久久久午夜福利| 久久精品一本到99热免费| 久久精品中文字幕无码绿巨人| 久久久久久精品免费看SSS| 粉嫩小泬无遮挡久久久久久| 青青国产成人久久91网| 日韩欧美亚洲综合久久 | 精品乱码久久久久久夜夜嗨| 久久综合亚洲色HEZYO国产| 婷婷五月深深久久精品| 精品久久综合1区2区3区激情 | 久久精品国产只有精品66| 亚洲日韩欧美一区久久久久我 | 亚洲日本久久久午夜精品| 99久久无码一区人妻a黑| 色青青草原桃花久久综合| 久久最新精品国产| 久久久无码一区二区三区| 久久婷婷色香五月综合激情| 国产午夜精品久久久久九九| 久久久无码精品亚洲日韩按摩| 久久人人爽人人爽人人片AV麻豆 | 久久影院亚洲一区| 国产精品久久自在自线观看| 久久午夜夜伦鲁鲁片免费无码影视 | 国产精品欧美久久久久天天影视 | 国产精品一区二区久久精品涩爱| 四虎国产精品免费久久久| 国产∨亚洲V天堂无码久久久 | 久久天天躁狠狠躁夜夜avapp | 91精品婷婷国产综合久久| 97久久精品人妻人人搡人人玩| 精品综合久久久久久98| 亚洲欧洲日产国码无码久久99| 少妇久久久久久被弄到高潮| 久久久久久国产精品无码下载| 久久久人妻精品无码一区| 久久99亚洲综合精品首页| 国产成人无码精品久久久免费| 国产三级久久久精品麻豆三级| 精品无码久久久久国产|