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

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

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

    Flyingis

    Talking and thinking freely !
    Flying in the world of GIS !
    隨筆 - 156, 文章 - 16, 評論 - 589, 引用 - 0
    數(shù)據(jù)加載中……

    數(shù)據(jù)結(jié)構(gòu)中避免數(shù)據(jù)項的重復

    抽象數(shù)據(jù)類型(ADT)是一種只能通過接口訪問的數(shù)據(jù)類型,它是字段與基于字段的操作所構(gòu)成的集合。這里的接口不是interface,而是訪問數(shù)據(jù)的途徑,接口把數(shù)據(jù)的表示和操作方法的實現(xiàn)完全分離開來。兩種最基本的ADT是堆棧和隊列,并且根據(jù)我們的需要,可以構(gòu)建更為復雜的ADT,例如可以對數(shù)據(jù)項進行計數(shù),檢查數(shù)據(jù)項是否存在重復等等。

    在很多實際應用中,我們都不允許存在數(shù)據(jù)項重復的情況,需要對用戶提交的重復數(shù)據(jù)進行合適的處理。讓用戶保證不提交重復的數(shù)據(jù)可以避免這種情況的發(fā)生,但顯然這種方法并不實際,既然使用ADT就是為了給使用它的程序員提供簡單明了的數(shù)據(jù)類型解決方案,那么我們就應該在ADT中來解決這個問題。以隊列為例,一般可以通過兩種策略來處理這個問題:

    1.        放棄新輸入的數(shù)據(jù)項:當最新放入隊列中的數(shù)據(jù)項已經(jīng)在隊列中時,放棄當前輸入的數(shù)據(jù)項。

    2.        放棄舊的數(shù)據(jù)項,保存新輸入的數(shù)據(jù)項:當最新放入隊列中的數(shù)據(jù)項已經(jīng)在隊列中時,放棄已經(jīng)存在于隊列中的數(shù)據(jù)項,保存當前放入的數(shù)據(jù)項。

        對于第一種處理方式,在一種特殊的情況下,數(shù)據(jù)項存儲的數(shù)據(jù)是0~N-1之間的整數(shù),那么可以通過增加一個新的數(shù)組a[i]或鏈表來儲存boolean類型數(shù)據(jù),當隊列中第i個位置上已經(jīng)存在數(shù)據(jù)i(i<=N-1),設(shè)置a[i]=boolean,那么可以通過a[i]來判斷數(shù)據(jù)i是否已經(jīng)存在于隊列中。第二種處理方式比第一種更為復雜一些,如果有必要,還可以讓用戶去選擇采取哪種策略來避免重復的數(shù)據(jù)項。但不管怎么樣,我們可以通過構(gòu)建不同類型的ADT,并在ADT中實現(xiàn)某些我們所需要的功能,將能極大限度地保證數(shù)據(jù)結(jié)構(gòu)和算法的靈活性與清晰的結(jié)構(gòu),使基于ADT的實現(xiàn)能滿足各種不同的具體應用,并方便類的重構(gòu)。

    posted on 2006-01-30 00:34 Flyingis 閱讀(1139) 評論(2)  編輯  收藏 所屬分類: Algorithm

    評論

    # re: 數(shù)據(jù)結(jié)構(gòu)中避免數(shù)據(jù)項的重復  回復  更多評論   

    不許重復的數(shù)據(jù)項,聽上去想是集合的概念.java collection framework 里的Set,你看是不是解決你說的問題呀. 當然set有不同數(shù)據(jù)結(jié)構(gòu)實現(xiàn)的子類
    2006-02-01 18:35 | 集合

    # re: 數(shù)據(jù)結(jié)構(gòu)中避免數(shù)據(jù)項的重復  回復  更多評論   

    Set的確實現(xiàn)了類似的功能,但不能滿足任何情況下功能上的需要;有時對于特定的數(shù)據(jù),需要考慮程序的運行效率.這兩種情況下都需要自己重新設(shè)計數(shù)據(jù)結(jié)構(gòu).即只設(shè)計自己需要的功能,并在特定情況下滿足效率上的需要.
    2006-02-01 22:31 | Flyingis
    主站蜘蛛池模板: 亚洲国产日韩女人aaaaaa毛片在线| 亚洲激情黄色小说| 噜噜综合亚洲AV中文无码| 免免费国产AAAAA片| 亚洲精品美女久久久久| 99久久人妻精品免费一区| 久久久久久亚洲精品中文字幕 | 2022久久国产精品免费热麻豆| 久久久久国色AV免费观看性色| 亚洲在成人网在线看| 无码免费午夜福利片在线| 亚洲a在线视频视频| 在线观看免费中文视频| 国产亚洲美女精品久久久| 两个人日本免费完整版在线观看1| 亚洲中文字幕无码久久综合网| 亚洲日本VA午夜在线影院| 国产在线观看www鲁啊鲁免费| 色妞www精品视频免费看| 亚洲一区二区三区AV无码| 99久热只有精品视频免费看 | 精品久久久久久国产免费了| 亚洲欧洲美洲无码精品VA | 久久99免费视频| 亚洲天堂一区二区三区四区| 女人毛片a级大学毛片免费| 免费精品国自产拍在线播放 | 亚洲国产精品一区二区第一页免| 亚洲人妖女同在线播放| 拔擦拔擦8x华人免费久久| 亚洲一区二区观看播放| 免费一级毛片不卡在线播放| 久9这里精品免费视频| 日本亚洲成高清一区二区三区 | 免费影院未满十八勿进网站| 亚洲AV日韩AV无码污污网站| 亚洲色精品vr一区二区三区| 在线视频观看免费视频18| 国产精品玖玖美女张开腿让男人桶爽免费看 | 卡1卡2卡3卡4卡5免费视频 | 久久国产精品免费一区|