<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
    主站蜘蛛池模板: 亚洲人成电影亚洲人成9999网| 国产精品va无码免费麻豆| 99精品视频在线观看免费| 国产人成网在线播放VA免费| 久久久久久精品成人免费图片| 黄瓜视频影院在线观看免费| 亚洲国产综合无码一区二区二三区| 国产亚洲美女精品久久久久狼| 亚洲黄页网在线观看| 免费一级特黄特色大片| 玖玖在线免费视频| 免费观看国产小粉嫩喷水| 免费精品人在线二线三线区别| 国产裸模视频免费区无码| 亚洲av无码无在线观看红杏| 亚洲AV无码一区二区三区DV| 久久99热精品免费观看动漫| 日本卡1卡2卡三卡免费| 1000部免费啪啪十八未年禁止观看| 免费黄网站在线观看| 免费日本黄色网址| 中文永久免费观看网站| 国产免费观看a大片的网站| 一级美国片免费看| 免费看黄视频网站| 亚洲AV无码资源在线观看| 亚洲综合激情五月丁香六月| 在线观看亚洲免费| 免费国产在线精品一区| 国产L精品国产亚洲区久久| 四虎亚洲精品高清在线观看| 久久久久久久岛国免费播放 | 91福利免费体验区观看区| 成人免费无码大片a毛片软件| 国产成人精品日本亚洲网站| 亚洲熟妇AV日韩熟妇在线| 免费夜色污私人影院在线观看| 国产精品亚洲色图| 色www永久免费视频| 亚洲砖码砖专无区2023| 亚洲最大av无码网址|