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

            飛天

            快樂(lè)的生活......

             

            馬踏棋盤(pán)問(wèn)題

                問(wèn)題描述:
            馬的遍歷問(wèn)題。在8×8方格的棋盤(pán)上,從任意指定方格出發(fā),為馬尋找一條走遍棋盤(pán)每一格并且只經(jīng)過(guò)一次的一條路徑。
                分析:
                   1.可以根據(jù)深度優(yōu)先搜索求解.
              
            回朔法

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

            //簡(jiǎn)單排序
            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;
                            }

                      }

            }

            //計(jì)算節(jié)點(diǎn)的出口數(shù)(估值)
            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
            ++;//回塑次數(shù) 
                  return false;

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

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

            評(píng)論

            # re: 馬踏棋盤(pán)問(wèn)題 2009-03-29 18:28 網(wǎng)友

            怎么不寫(xiě)析構(gòu)函數(shù)啊?  回復(fù)  更多評(píng)論   

            # re: 馬踏棋盤(pán)問(wèn)題[未登錄](méi) 2013-06-02 11:34 1

            1  回復(fù)  更多評(píng)論   

            導(dǎo)航

            統(tǒng)計(jì)

            常用鏈接

            留言簿(2)

            隨筆分類(lèi)

            隨筆檔案

            文章分類(lèi)

            文章檔案

            Blogs

            搜索

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            国产精品天天影视久久综合网| 欧美精品一区二区久久| 97超级碰碰碰久久久久| 国产精品九九久久精品女同亚洲欧美日韩综合区 | 国产视频久久| 久久久久亚洲国产| 狠狠色丁香久久综合五月| 亚洲?V乱码久久精品蜜桃| 精品久久8x国产免费观看| 国产成人精品久久亚洲高清不卡| 久久一区二区三区免费| AV狠狠色丁香婷婷综合久久| 久久久久国产一级毛片高清板| 久久婷婷五月综合97色一本一本| AA级片免费看视频久久| 青草国产精品久久久久久| 人妻丰满?V无码久久不卡| 久久久久四虎国产精品| 麻豆亚洲AV永久无码精品久久| 久久久国产精华液| 99久久国产综合精品五月天喷水| 日产精品久久久久久久性色 | 久久精品国产亚洲αv忘忧草| 四虎国产精品免费久久5151| 亚洲狠狠婷婷综合久久蜜芽| 亚洲精品国产综合久久一线| 久久精品国产亚洲Aⅴ香蕉| 久久久精品国产sm调教网站 | 无码AV中文字幕久久专区| 一级做a爰片久久毛片看看| 欧美激情精品久久久久久| 国产精品免费看久久久香蕉| 亚洲欧美精品伊人久久| 91精品国产综合久久香蕉| 精品国产福利久久久| 久久福利青草精品资源站免费 | 久久亚洲中文字幕精品一区| 精品综合久久久久久88小说| 国产日韩久久久精品影院首页| 免费国产99久久久香蕉| 精品无码久久久久久国产|