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

            飛天

            快樂的生活......

             

            馬踏棋盤問題

                問題描述:
            馬的遍歷問題。在8×8方格的棋盤上,從任意指定方格出發,為馬尋找一條走遍棋盤每一格并且只經過一次的一條路徑。
                分析:
                   1.可以根據深度優先搜索求解.
              
            回朔法

                  2.優化之后的算法:
                  在每個結點對其子結點進行選取時,優先選擇‘出口’最小的進行搜索,‘出口’的意思是在這些子結點中它們的可行子結點的個數,也就是‘孫子’結點越少的越優先跳,為什么要這樣選取,這是一種局部調整最優的做法,如果優先選擇出口多的子結點,那出口少的子結點就會越來越多,很可能出現‘死’結點(顧名思義就是沒有出口又沒有跳過的結點),這樣對下面的搜索純粹是徒勞,這樣會浪費很多無用的時間,反過來如果每次都優先選擇出口少的結點跳,那出口少的結點就會越來越少,這樣跳成功的機會就更大一些。這種算法稱為為貪心算法,也叫貪婪算法或啟發示算法,它對整個求解過程的局部做最優調整,它只適用于求較優解或者部分解,而不能求最優解。這樣的調整方法叫貪心策略,至于什么問題需要什么樣的貪心策略是不確定的,具體問題具體分析。實驗可以證明馬遍歷問題在運用到了上面的貪心策略之后求解速率有非常明顯的提高,如果只要求出一個解甚至不用回溯就可以完成,因為在這個算法提出的時候世界上還沒有計算機,這種方法完全可以用手工求出解來,其效率可想而知。

            //簡單排序
            void Horse::sort(Node * node,int len)
            {
                    
            for(int i=0;i<len-1;i++)
                      
            for(int j=i+1;j<len;j++)
                      
            {
                            
            if(node[i].value>node[j].value)
                            
            {
                                    Node temp
            =node[i];
                                    node[i]
            =node[j];
                                    node[j]
            =temp;
                            }

                      }

            }

            //計算節點的出口數(估值)
            void Horse::ways_out(Node & node)
            {
                  
            int m,n;

                  
            for(int i=0;i<8;++i)
                  
            {
                      m
            =node.x+nx[i];
                      n
            =node.y+ny[i];
                      
            if(m<0||n<0||m>=width||n>=height)
                         
            continue;
                      
            if(borad[m][n]==0)
                            node.value
            ++;
                  }

            }


            bool Horse::dfs(
            int m,int n,int step)
            {
                  
            if(borad[m][n]!=0return false;
                  borad[m][n]
            =step;
                  
            if(step==size)         
                     
            throw 1;
                  
            int newx,newy;
                  Node node[
            8];
                  
            int len=0;
                  
            for(int i=0;i<8;++i)
                  
            {
                      newx
            =m+nx[i];
                      newy
            =n+ny[i];
                      
            if(newx<0||newy<0||newx>=width||newy>=height)
                         
            continue;

                      node[len].x
            =newx;
                      node[len].y
            =newy;
                      node[len].value
            =0;
                      ways_out(node[len]);
                      len
            ++;
                      
            //dfs(newx,newy,step+1);
                  }


                  sort(node,len);
                  
            for(int i=0;i<len;++i)
                      dfs(node[i].x,node[i].y,step
            +1);

                  borad[m][n]
            =0;
                  backcount
            ++;//回塑次數 
                  return false;

            }
                下載
                參考文章:
                 http://www.programfan.com/blog/article.asp?id=4148

            posted on 2008-01-19 13:12 飛天 閱讀(3786) 評論(2)  編輯 收藏 引用 所屬分類: 算法描述

            評論

            # re: 馬踏棋盤問題 2009-03-29 18:28 網友

            怎么不寫析構函數啊?  回復  更多評論   

            # re: 馬踏棋盤問題[未登錄] 2013-06-02 11:34 1

            1  回復  更多評論   

            導航

            統計

            常用鏈接

            留言簿(2)

            隨筆分類

            隨筆檔案

            文章分類

            文章檔案

            Blogs

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            国内精品久久久久久久久| 久久免费视频6| 国产69精品久久久久777| 久久久久亚洲Av无码专| 久久久久久a亚洲欧洲aⅴ| 精品久久综合1区2区3区激情| 久久人人爽人人澡人人高潮AV| 久久亚洲AV成人无码软件| 国内精品伊人久久久久AV影院| 久久av免费天堂小草播放| 国产午夜精品久久久久九九| 久久久久亚洲AV综合波多野结衣| 亚洲精品乱码久久久久久久久久久久| 四虎国产永久免费久久| 欧美亚洲国产精品久久| 久久精品国产亚洲AV大全| 亚洲国产小视频精品久久久三级 | 91久久成人免费| 亚洲欧美日韩中文久久| 国产精品美女久久久久av爽| 波多野结衣AV无码久久一区| 老司机国内精品久久久久| 亚洲国产一成人久久精品 | 久久AV高潮AV无码AV| 久久99精品免费一区二区| 久久精品国产一区二区三区日韩| 亚洲va久久久噜噜噜久久天堂| 久久精品国产99久久久香蕉| 久久综合久久综合九色| 久久国产精品无码一区二区三区| 亚洲精品乱码久久久久久蜜桃不卡| 久久久久久国产精品免费免费| 天天爽天天爽天天片a久久网| 国产精品久久久久天天影视| 一本色道久久88精品综合 | 午夜精品久久影院蜜桃| 国产精品伊人久久伊人电影| 色综合久久88色综合天天| 亚洲一本综合久久| 观看 国产综合久久久久鬼色 欧美 亚洲 一区二区| 亚洲精品国产美女久久久|