• <fieldset id="8imwq"><menu id="8imwq"></menu></fieldset>
  • <bdo id="8imwq"><input id="8imwq"></input></bdo>
    最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
    問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
    當(dāng)前位置: 首頁 - 科技 - 知識(shí)百科 - 正文

    C#各種集合操作的性能總結(jié)

    來源:懂視網(wǎng) 責(zé)編:小采 時(shí)間:2020-11-27 22:42:07
    文檔

    C#各種集合操作的性能總結(jié)

    C#各種集合操作的性能總結(jié):本文主要記錄的是C#各種集合操作的性能,下面的標(biāo)記說明描述標(biāo)記的時(shí)間,下面的表格對(duì)比各種集合各種操作的時(shí)間. 標(biāo)記說明: 1.O(1) 表示無論集合中有多少項(xiàng),這個(gè)操作需要的時(shí)間都不變,例如,ArraryLIst的Add()方法就O(1), 無論集合中有多少元素,在列表尾部添加
    推薦度:
    導(dǎo)讀C#各種集合操作的性能總結(jié):本文主要記錄的是C#各種集合操作的性能,下面的標(biāo)記說明描述標(biāo)記的時(shí)間,下面的表格對(duì)比各種集合各種操作的時(shí)間. 標(biāo)記說明: 1.O(1) 表示無論集合中有多少項(xiàng),這個(gè)操作需要的時(shí)間都不變,例如,ArraryLIst的Add()方法就O(1), 無論集合中有多少元素,在列表尾部添加

    本文主要記錄的是C#各種集合操作的性能,下面的標(biāo)記說明描述標(biāo)記的時(shí)間,下面的表格對(duì)比各種集合各種操作的時(shí)間.

    標(biāo)記說明:
    1.O(1) 表示無論集合中有多少項(xiàng),這個(gè)操作需要的時(shí)間都不變,例如,ArraryLIst的Add()方法就O(1), 無論集合中有多少元素,在列表尾部添加一個(gè)新的元素的時(shí)間都是相同的.
    2. O(n)表示對(duì)于集合中的每個(gè)元素,需要增加的時(shí)間量都是相同的,如果需要重新給集合分
    配內(nèi)存,ArrayList的Add()方法就O(n),改變?nèi)萘?需要復(fù)制列表,復(fù)制的時(shí)間隨元素的增加和線性增加.
    3. O(log n)表示操作需要的時(shí)間隨著集合中元素的增加和增加,但每個(gè)元素增加的時(shí)間不是
    線性的.而是呈對(duì)數(shù)曲線,在集合中插入操作時(shí),SortedDictionary<Tkey,Tvalue>就是
    O(log n),而SortedList<Tkey,Tvalue> 就是O(n),這里SortedDictionary<Tkey,Tvalue>
    要快的多.因?yàn)樗跇湫谓Y(jié)構(gòu)中插入元素的效率比列表高的多.

    下表顯示各種集合的操作時(shí)間:
    注:如果單元格中有多個(gè)大O值,表示集合需要重置大小,該操作需要一定的時(shí)間
    如果單元格內(nèi)容是no,就表示不支持這種操作.

    集合 Add Insert Remove Item Sort Find
    List<T> 如果集合必須重置大小就是O(1)或O(n) O(n) O(n) O(1) O(n log n)最壞情況O(n^2) O(n)
    Stack<T>(棧) Push(),如果棧必須重置大小,就是O(1)或O(n) no Pop(),O(1) no no no
    Queue<T>(列隊(duì)) Enqueue(),如果棧必須重置大小,就是O(1)或O(n) no Dequeu(),O(1) no no no
    HastSet<T>(無序列表) 如果棧必須重置大小,就是O(1)或O(n)

    Add()

    O(1)或O(n)

    O(1) no no no
    LinkedList<T>(鏈表) AddLast(),O(1) AddAfter(),O(1) O(1) no no O(n)
    Dictionary<Tkey,TValue> O(1) 或 O(n) no O(1) O(1) no no
    SortedDictionary<Tkey,Tvalue> O(log n) no O(log n) O(log n) no no
    SortedList<Tkey,Tvalue>

    無序數(shù)據(jù)為O(n),如果必選重置大小,到列表的尾部就是

    O(log n)

    no O(n) 讀寫是O(log n),如果鍵在列表中,就是O(log n),如果鍵不在列表中就是O(n). no no

    總結(jié):
    數(shù)組的大小是固定的,但可以使用列表作為動(dòng)態(tài)增長集合,列隊(duì)以先進(jìn)先出的方式訪問元素,棧以后進(jìn)先出的方式訪問元素, 鏈表可以快速的插入和刪除元素,但搜索比較慢,通過鍵和值可以使用字典,它的搜索和插入操作比較快,集(Hashset<T>) 是用于無序的唯一項(xiàng).
    代碼改變世界,記錄知識(shí).

    聲明:本網(wǎng)頁內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問題請(qǐng)及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

    文檔

    C#各種集合操作的性能總結(jié)

    C#各種集合操作的性能總結(jié):本文主要記錄的是C#各種集合操作的性能,下面的標(biāo)記說明描述標(biāo)記的時(shí)間,下面的表格對(duì)比各種集合各種操作的時(shí)間. 標(biāo)記說明: 1.O(1) 表示無論集合中有多少項(xiàng),這個(gè)操作需要的時(shí)間都不變,例如,ArraryLIst的Add()方法就O(1), 無論集合中有多少元素,在列表尾部添加
    推薦度:
    標(biāo)簽: 集合 性能 總結(jié)
    • 熱門焦點(diǎn)

    最新推薦

    猜你喜歡

    熱門推薦

    專題
    Top
    主站蜘蛛池模板: 亚洲国产精品无码久久久蜜芽| 国产香蕉国产精品偷在线 | 四虎精品免费永久免费视频| 蜜桃麻豆www久久国产精品| 最新精品露脸国产在线 | 99国产精品久久久久久久成人热| 精品人妻人人做人人爽| 国产成人精品手机在线观看| 久久伊人精品青青草原日本| 亚洲欧美日韩国产精品一区二区| 亚洲国产精品无码久久SM| 国产在线精品一区二区高清不卡| 99RE6热在线精品视频观看| 亚洲精品国偷自产在线| 久久久久久久久久免免费精品| 99亚洲精品视频| 欧美精品福利在线视频| 亚洲精品欧美日韩| 亚洲精品99久久久久中文字幕| 国产亚洲精品美女久久久| 亚洲欧美日韩另类精品一区二区三区| 精品人妻伦一二三区久久| 久久香蕉超碰97国产精品| 久久亚洲精品中文字幕三区| 久久精品国产亚洲一区二区三区| 最新国产精品亚洲| 网友偷拍日韩精品| 久久噜噜久久久精品66| 国产精品小黄鸭一区二区三区| 亚洲精品无码久久久久sm| 亚洲精品偷拍视频免费观看| 欧美精品一区二区在线精品| 久久精品成人免费观看97| 国内精品久久久久久久涩爱| 国产精品免费久久久久影院| 国产中老年妇女精品| 嫖妓丰满肥熟妇在线精品| 无码精品久久久天天影视| 99久久99久久精品国产片| 在线欧美v日韩v国产精品v| 国产99视频精品专区|