<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    隨筆 - 71  文章 - 15  trackbacks - 0
    <2025年5月>
    27282930123
    45678910
    11121314151617
    18192021222324
    25262728293031
    1234567

    因為口渴,上帝創造了水;
    因為黑暗,上帝創造了火;
    因為我需要朋友,所以上帝讓你來到我身邊
    Click for Shaanxi xi'an, Shaanxi Forecast
    ╱◥█◣
      |田|田|
    ╬╬╬╬╬╬╬╬╬╬╬
    If only I have such a house!
    〖總在爬山 所以艱辛〗
    Email:myesjoy@yahoo.com.cn
    NickName:yesjoy
    MSN:myesjoy@hotmail.com
    QQ:150230516

    〖總在尋夢 所以苦痛〗

    常用鏈接

    留言簿(3)

    隨筆分類

    隨筆檔案

    文章分類

    文章檔案

    Hibernate在線

    Java友情

    Java認證

    linux經典

    OA系統

    • ¤易能協同辦公系統¤
    • 流程管理、知識管理、客戶關系管理、輔助辦公
    • ¤黃城網絡辦公系統3.0¤
    • B/S結構,適用于Intranet/Internet應用,實現無地域限制的全球辦公,具有郵件管理、業務管理、網絡硬盤、智能工作流等功能。

    Spring在線

    Structs在線

    專家專欄

    企業信息化

    大型設備共享系統

    工作流

    工作流產品

    網上購書

    搜索

    •  

    最新評論

    閱讀排行榜

    評論排行榜

    轉自:http://m.tkk7.com/dengyin2000/archive/2006/03/12/34902.html
    大學的數據結構和算法根本就是混過來的,某天在某某論壇里有個關于數據結構和算法到底在日常的編程到底有多大的用處。對于我來說,我并不覺得我用上了那些講的數據結構和算法。Java Collection Framework已經跟我們做了這些。我已經能非常熟練的使用Collection里面的類庫。但是我們用的基本上都是那些線性集合(堆棧,隊列,列表,Set),非線性集合(樹,堆,散列和圖)我感覺比較少用到。我也主要是想對非線性集合做一些比較。線性集合比較簡單。

     

     第一章到第九章都是講線性集合, 也比較容易理解, 在這里就忽略掉。第十章是講遞歸算法。我對這章比較感興趣,用遞歸實現某個算法真的感覺非常優雅,代碼短而少,許多非線性集合都是用遞歸來實現的。但也有他的缺點, 對方法的每次遞歸調用都會生成新的局部變量和局部參數。假如遞歸層次太多的話,就會消耗太多的stack。

     

    任何遞歸定義都必須有一個非遞歸部分;這個非遞歸部分叫做基本情況,它使的遞歸跳出無窮循環遞歸。

    Ex 1 1~N的累加過程,數值1N的累加可以看成是1N1的累加加上N。

     

           public int sum(int num){

                  
    int result = 0;

                  
    if (num == 1){

                         
    return 1;

                  }


                  
    return result + num + sum(num - 1);

           }

     

    這里的基本情況就是但num==1的時候。 當然這個可以不用遞歸來處理,用一個for就行了(而且比用遞歸更直觀)。我們必須能判斷什么時候使用遞歸,什么時候不使用遞歸,所有問題都可以使用迭代(for循環)解決問題。不過有些情況下,迭代方式過于復雜,對某些問題,遞歸可以寫出短小而優雅的代碼。

     

     

    直接遞歸和間接遞歸,方法調用自己,這就是直接遞歸(如上個例子)。方法調用另一個方法,最終導致再調用原方法。這就是間接遞歸。

     

    河內塔問題(Towers of Hanoi)(可以上網找找這個經典問題的描述)

    規則:

    l         一次只能移動一張圓盤

    l         不能將大盤放在小盤的上方

    l         除了那張在柱子之間搬動的圓盤之外,所有圓盤都必須在某根柱子上

     

    策略:

    l         將最上方的N1張圓盤從最初的柱子移到那根多處的柱子上

    l         將最大的圓盤從最初的柱子移動到最終的柱子上

    l         再將那個多出柱子上的N1張圓盤移到最終的柱子上

     

    public      class TowersOfHanoi{

                  
    private int totalDisks;

                  
    // ------------------------------------------------------

                  
    // Sets up the puzzle with the specified number of disks

                  
    // ------------------------------------------------------

                  
    public TowersOfHanoi(int disks){

                         
    this.totalDisks = disks;

                  }


                  
    // ----------------------------------------------------------

                  
    // Performs the initial call to moveTower to solve the puzzle.

                  
    // Moves the disks from tower 1 to tower 3 using tower 2

                  
    // ----------------------------------------------------------

                  
    public void solve(){

                         moveTower(totalDisks, 
    13,2);

                  }


                  
    // -----------------------------------------------------------------

                  
    // Moves the specified number of disks from one tower to another by 

                  
    // moving a subtower of n-1 disks out of the way, moving one disk, 

                  
    // then moving the subtower back, Base case of 1 disk.

                  
    // -----------------------------------------------------------------

                  
    private void moveTower(int numDisks, int start, int end, int temp) {

                         
    if (numDisks == 1){

                                moveOneDisk(start, end);

                         }
    else{

                                moveTower(numDisks
    -1, start, temp, end);

                                moveOneDisk(start, end);

                                moveTower(numDisks
    -1, temp, end, start);

                         }


                  }


                  
    private void moveOneDisk(int start, int end) {

                         System.out.println(
    "Move one disk from " + start + " to " + end);

                  }


           }

    posted on 2007-06-19 15:20 ★yesjoy★ 閱讀(300) 評論(0)  編輯  收藏 所屬分類: 算法總結
    主站蜘蛛池模板: 亚洲一区二区三区无码国产| 国产国拍亚洲精品mv在线观看 | 青草草在线视频永久免费| 亚洲大香人伊一本线| 91免费国产自产地址入| 亚洲福利视频网址| 久久久久国产精品免费免费搜索 | yellow视频免费看| 国产亚洲精品a在线观看 | 18女人腿打开无遮掩免费| 亚洲精品高清国产麻豆专区| 99国产精品永久免费视频 | av午夜福利一片免费看久久| 亚洲午夜AV无码专区在线播放 | 免费人成视频在线播放| 亚洲黄黄黄网站在线观看| 二个人看的www免费视频| 亚洲AV永久纯肉无码精品动漫| 久久免费动漫品精老司机| 亚洲一区二区三区不卡在线播放| 性色av免费观看| 一级中文字幕乱码免费| 久久精品国产亚洲av麻豆 | 国内精品99亚洲免费高清| 国产美女被遭强高潮免费网站| 亚洲AV日韩AV永久无码色欲 | 亚洲&#228;v永久无码精品天堂久久| 一区二区视频在线免费观看| 婷婷精品国产亚洲AV麻豆不片| 免费可以在线看A∨网站| 国产精品亚洲综合一区在线观看| 中文字幕无码精品亚洲资源网| 99久久久国产精品免费蜜臀| 国产精品亚洲一区二区在线观看 | 又粗又长又爽又长黄免费视频| 久久亚洲免费视频| 白白国产永久免费视频| 成全视频在线观看免费| 亚洲色丰满少妇高潮18p| 色久悠悠婷婷综合在线亚洲| 免费A级毛片无码免费视|