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

            The Fourth Dimension Space

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

            ACRUSH(樓天成)八數碼問題源代碼

            題目描述
            八方塊移動游戲要求從一個含8個數字(用1-8表示)的方塊以及一個空格方塊(用0表示)的3x3矩陣的起始狀態開始,不斷移動該空格方塊以使其和相鄰的方塊互換,直至達到所定義的目標狀態。空格方塊在中間位置時有上、下、左、右4個方向可移動,在四個角落上有2個方向可移動,在其他位置上有3個方向可移動。例如,假設一個3x3矩陣的初始狀態為:
               8 0 3
               2 1 4
               7 6 5
            目標狀態為:
               1 2 3
               8 0 4
               7 6 5
            則一個合法的移動路徑為:
               8 0 3    8 1 3    8 1 3    0 1 3    1 0 3    1 2 3
               2 1 4 => 2 0 4 => 0 2 4 => 8 2 4 => 8 2 4 => 8 0 4
               7 6 5    7 6 5    7 6 5    7 6 5    7 6 5    7 6 5

            另外,在所有可能的從初始狀態到目標狀態的移動路徑中,步數最少的路徑被稱為最短路徑;在上面的例子中,最短路徑為5。如果不存在從初試狀態到目標狀態的任何路徑,則稱該組狀態無解。

            請設計有效的(細節請見評分規則)算法找到從八方塊的某初試狀態到某目標狀態的所有可能路徑中的最短路徑,并用C/C++實現。

            輸入數據
            程序需讀入已被命名為start.txt的初始狀態和已被命名為goal.txt的目標狀態,這兩個文件都由9個數字組成(0表示空格,1-8表示8個數字方塊),每行3個數字,數字之間用空格隔開。

            輸出數據
            如果輸入數據有解,輸出一個表示最短路徑的非負的整數;如果輸入數據無解,輸出-1。

            自測用例
            如果輸入為:start.txtgoal.txt,則產生的輸出應為:
            5

            又例,如果用
            7 8 4
            3 5 6
            1 0 2
            替換start.txt中的內容,則產生的輸出應為:
            21

            評分規則
            1)我們將首先使用和自測用例不同的10個start.txt以及相同的goal.txt,每個測試用例的運行時間在一臺Intel Xeon 2.80GHz 4 CPU/6G 內存的Linux機器上應不超過10秒(內存使用不限制),否則該用例不得分;

            2)每個選手的總分(精確到小數點后6位)=10秒鐘內能產生正確結果的測試用例數量x10+(1/產生這些正確結果的測試用例的平均運行毫秒);

            3)如果按此評分統計仍不能得出總決賽將決出的一、二、三等獎共計九名獲獎者,我們將先設N=2,然后重復下述過程直至產生最高的9位得分:用隨機生成的另外10個有解的start.txt再做測試,并對這10*N個測試用例用2)中公式重新計算總分,N++。



            //冠軍ACRush的代碼: 
            //轉載自:http://star.baidu.com/data/demo/ACRush.txt 

            #include 
            <stdio.h> 
            #include 
            <stdlib.h> 
            #include 
            <string.h> 

            const int hashsize=70001
            const int maxnode=50000
            const int maxp=40
            const int ten[]={1,10,100,1000,10000,100000,1000000,10000000,100000000}
            const int C[]={2,3,2,3,4,3,2,3,2}
            const int EP[][4]={{1,3,0,0},{0,2,4,0},{1,5,0,0},{0,4,6,0},{1,3,5,7},{2,4,8,0},{3,7,0,0},{4,6,8,0},{5,7,0,0}}

            struct Tlist 

              
            int data,d; 
              Tlist 
            *next; 
            }

            struct Thashpoint 

              
            int data; 
              Thashpoint 
            *next; 
            }

            //Memory 
            int ID; 
            Tlist listM[maxnode],
            *q; 
            Thashpoint hashM[maxnode],
            *p; 
            //data 
            int src,dest; 
            //heap 
            Tlist *head[maxp],*expand[maxp],*lp1,*lp2; 
            //Hash 
            Thashpoint *hash[hashsize]; 
            //expand 
            int nowp,A[9],arcT[9],dist[9][9],b,depth,swap[9][9]; 
            int data,G,newdata,newG; 
            bool find_answer; 

            void readdata(const char *filename,int &data) 

              
            int i,v; 
              FILE 
            *f=fopen(filename,"r"); 
              data
            =0
              
            for (i=0;i<9;i++
              

                fscanf(f,
            "%d",&v); 
                data
            =data+v*ten[i]; 
              }
             
              fclose(f); 
            }
             
            bool check_noanswer() 

              
            int p[9],i,b1,b2; 
              
            bool vis[9]; 
              
            for (i=0;i<9;i++
                p[i]
            =arcT[src/ten[i]%10]; 
              
            for (b1=0; src/ten[b1]%10!=0;b1++); 
              
            for (b2=0;dest/ten[b2]%10!=0;b2++); 
              
            int countP=0
              memset(vis,
            false,sizeof(vis)); 
              
            for (i=0;i<9;i++
                
            if (!vis[i]) 
                

                  countP
            ++
                  
            for (int k=i;!vis[k];k=p[k]) 
                    vis[k]
            =true
                }
             
              
            return (countP-dist[b1][b2])%2==0
            }
             
            void preprocess() 

              ID
            =0
              find_answer
            =false
              memset(hash,
            0,sizeof(hash)); 
              memset(head,
            0,sizeof(head)); 
              memset(expand,
            0,sizeof(expand)); 
              
            for (int k=0;k<9;k++
                arcT[dest
            /ten[k]%10]=k; 
              
            for (int u=0;u<9;u++
                
            for (int v=0;v<9;v++
                

                  dist[u][v]
            =abs(u/3-v/3)+abs(u%3-v%3); 
                  swap[u][v]
            =ten[u]-ten[v]; 
                }
             
            }
             
            void addnode() 

              
            if (newdata==dest) 
              

                printf(
            "%d\n",depth); 
                find_answer
            =true
                
            return
              }
             
              
            int address=newdata%hashsize; 
              
            for (p=hash[address];p!=NULL;p=p->next) 
                
            if (p->data==newdata) 
                  
            return
              
            if (ID==maxnode) 
                
            return
              p
            =&hashM[ID]; 
              p
            ->data=newdata; 
              p
            ->next=hash[address]; 
              hash[address]
            =p; 
              q
            =&listM[ID]; 
              ID
            ++
              q
            ->data=newdata; 
              q
            ->d=depth; 
              
            if (newG>=maxp) 
                
            return
              
            if (newG==nowp) 
              

                q
            ->next=expand[depth]; 
                expand[depth]
            =q; 
              }
             
              
            else 
              

                q
            ->next=head[newG]; 
                head[newG]
            =q; 
              }
             
            }
             
            void solve() 

              nowp
            =-1
              newdata
            =src; 
              newG
            =0
              
            for (int k=0;k<9;k++
                
            if (src/ten[k]%10!=0
                  newG
            +=dist[arcT[src/ten[k]%10]][k]; 
              depth
            =0
              addnode(); 
              
            if (find_answer) 
                
            return
              
            for (int p=0;p<maxp;p++if (head[p]!=NULL) 
              

                nowp
            =p; 
                
            for (lp1=head[p];lp1!=NULL;lp1=lp2) 
                

                  lp2
            =lp1->next; 
                  lp1
            ->next=expand[lp1->d]; 
                  expand[lp1
            ->d]=lp1; 
                }
             
                
            for (int d=0;d<=p;d++
                  
            for (;expand[d]!=NULL;) 
                  

                    data
            =expand[d]->data; 
                    G
            =p-expand[d]->d; 
                    depth
            =expand[d]->d+1
                    expand[d]
            ->d=-2
                    expand[d]
            =expand[d]->next; 
                    
            for (b=0;data/ten[b]%10!=0;b++); 
                    
            for (int v=0;v<C[b];v++
                    

                      
            int u=EP[b][v]; 
                      
            int c=data/ten[u]%10
                      newdata
            =data+swap[b][u]*c; 
                      c
            =arcT[c]; 
                      newG
            =depth+G-dist[c][u]+dist[c][b]; 
                      addnode(); 
                      
            if (find_answer) 
                        
            return
                    }
             
                  }
             
              }
             
              printf(
            "-1\n"); 
            }
             
            int main() 

              readdata(
            "start.txt",src); 
              readdata(
            "goal.txt",dest); 
              preprocess(); 
              
            if (check_noanswer()) 
                printf(
            "-1\n"); 
              
            else 
                solve(); 
              
            return 0
            }
             

            posted on 2009-05-22 02:24 abilitytao 閱讀(18270) 評論(6)  編輯 收藏 引用

            評論

            # re: ACRUSH(樓天成)八數碼問題源代碼 2009-11-22 19:56 張甡華

            八數碼問題存在沒解的可能性嗎?(排除目標不是初始狀態的一個排列的情況)

            qq:46522649  回復  更多評論   

            # re: ACRUSH(樓天成)八數碼問題源代碼 2010-12-10 12:47 zlly

            orz abilitytao   回復  更多評論   

            # re: ACRUSH(樓天成)八數碼問題源代碼 2011-09-28 22:23 夜痕

            @張甡華
            應該是存在的  回復  更多評論   

            # re: ACRUSH(樓天成)八數碼問題源代碼 2015-04-07 22:09 cai ji

            我嚴重懷疑樓天城違反比賽規則,依我看樓天城用的是c的代碼 卻用的是c++的編譯器
            c里面不可能struct 這么定義這么實用的。必須有struct符號,而且看他的代碼很多處還實用引用這個c里面沒有的概念  回復  更多評論   

            # re: ACRUSH(樓天成)八數碼問題源代碼[未登錄] 2015-07-18 14:19 123

            @cai ji
            你逗呀,特么的都說了可以用c/c++。。。  回復  更多評論   

            # re: ACRUSH(樓天成)八數碼問題源代碼 2015-10-20 16:54 dgsdg 1

            gadrgadfg  回復  更多評論   

            久久久久中文字幕| 久久精品国产99久久无毒不卡| 久久99国产综合精品免费| 伊人久久精品无码av一区| 亚洲国产精品无码久久98| 国内精品久久久久影院薰衣草| 国产成人综合久久精品红| 久久SE精品一区二区| 久久综合给合久久狠狠狠97色| 久久精品国产亚洲av影院 | 国产999精品久久久久久| 色综合久久中文色婷婷| 99久久精品国产一区二区三区| 久久免费观看视频| 无码国内精品久久综合88 | 久久久久国产精品麻豆AR影院 | 久久综合鬼色88久久精品综合自在自线噜噜 | 成人国内精品久久久久影院VR| 久久久久九国产精品| 久久久久久综合网天天| 久久综合久久久| 无码人妻久久一区二区三区蜜桃| 久久精品国产久精国产思思 | 93精91精品国产综合久久香蕉| 久久久久亚洲AV综合波多野结衣| 国产偷久久久精品专区| 青青草国产成人久久91网| 久久婷婷五月综合97色直播| 国产精品久久国产精麻豆99网站 | 久久这里的只有是精品23| 狠狠色婷婷久久一区二区三区| 久久久久久A亚洲欧洲AV冫| 欧美牲交A欧牲交aⅴ久久| 精品久久久久久久久久中文字幕 | 国产一区二区三区久久精品| 久久99精品国产麻豆不卡| 久久久噜噜噜www成人网| 午夜精品久久久久久影视777 | 久久久久噜噜噜亚洲熟女综合 | 无码8090精品久久一区| 香蕉久久夜色精品国产小说|