欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

Java基于二分搜索樹(shù)、鏈表如何實(shí)現(xiàn)集合Set復(fù)雜度分析-創(chuàng)新互聯(lián)

小編給大家分享一下Java基于二分搜索樹(shù)、鏈表如何實(shí)現(xiàn)集合Set復(fù)雜度分析,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!

怒江州ssl適用于網(wǎng)站、小程序/APP、API接口等需要進(jìn)行數(shù)據(jù)傳輸應(yīng)用場(chǎng)景,ssl證書(shū)未來(lái)市場(chǎng)廣闊!成為創(chuàng)新互聯(lián)的ssl證書(shū)銷(xiāo)售渠道,可以享受市場(chǎng)價(jià)格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:18980820575(備注:SSL證書(shū)合作)期待與您的合作!

兩種集合類(lèi)的復(fù)雜度分析

在Java底層基于二叉搜索樹(shù)實(shí)現(xiàn)集合和映射 和Java底層基于鏈表實(shí)現(xiàn)集合和映射中以二分搜索樹(shù)和鏈表作為底層實(shí)現(xiàn)了集合Set,在本節(jié)就兩種集合類(lèi)的復(fù)雜度分析進(jìn)行分析:
測(cè)試內(nèi)容:Java底層基于二叉搜索樹(shù)實(shí)現(xiàn)集合和映射和Java底層基于鏈表實(shí)現(xiàn)集合和映射中使用的書(shū)籍。
測(cè)試方法:測(cè)試兩種集合類(lèi)查找單詞所用的時(shí)間

 //創(chuàng)建一個(gè)測(cè)試方法 Set<String> set:他們可以是實(shí)現(xiàn)了該接口的LinkedListSet和BSTSet對(duì)象
 private static double testSet(Set<String> set, String filename) {
  //計(jì)算開(kāi)始時(shí)間
  long startTime = System.nanoTime();
  System.out.println("Pride and Prejudice");
  //新建一個(gè)ArrayList存放單詞
  ArrayList<String> words1 = new ArrayList<>();
  //通過(guò)這個(gè)方法將書(shū)中所以單詞存入word1中
  FileOperation.readFile(filename, words1);
  System.out.println("Total words : " + words1.size());

  //增強(qiáng)for循環(huán),定一個(gè)字符串word去遍歷words
  //底層的話會(huì)把ArrayList words1中的值一個(gè)一個(gè)的賦值給word
  for (String word : words1)
   set.add(word);//不添加重復(fù)元素
  System.out.println("Total different words : " + set.getSize());

  //計(jì)算結(jié)束時(shí)間
  long endTime = System.nanoTime();
  return (endTime - startTime) / 1000000000.0;//納秒為單位
 }

 public static void main(String[] args) {
  //基于二分搜索的集合
  BSTSet<String> bstSet = new BSTSet<>();
  double time1 = testSet(bstSet, "pride-and-prejudice.txt");
  System.out.println("BSTSet:" + time1 + "s");
  System.out.println("————————————————————");
  //基于鏈表實(shí)現(xiàn)的集合
  LinkedListSet<String> linkedListSet = new LinkedListSet<>();
  double time2 = testSet(linkedListSet, "pride-and-prejudice.txt");
  System.out.println("linkedListSet:" + time2 + "s");

 }

結(jié)果:BSTSet的速度比LinkedListed的速度快

Java基于二分搜索樹(shù)、鏈表如何實(shí)現(xiàn)集合Set復(fù)雜度分析

集合的時(shí)間復(fù)雜度分析:

1.鏈表情況

Java基于二分搜索樹(shù)、鏈表如何實(shí)現(xiàn)集合Set復(fù)雜度分析

2.二叉搜索樹(shù)的情況

在基于二叉搜索樹(shù)的情況下,增加、查詢、刪除的與二叉搜索樹(shù)的深度有關(guān),每次操作均為從根節(jié)點(diǎn)到某一一支子樹(shù)的葉子節(jié)點(diǎn)之間進(jìn)行操作,時(shí)間復(fù)雜度為0(h),h表示二叉搜索樹(shù)的高度(層數(shù))。

Java基于二分搜索樹(shù)、鏈表如何實(shí)現(xiàn)集合Set復(fù)雜度分析

二叉搜索樹(shù)復(fù)雜度如下:

Java基于二分搜索樹(shù)、鏈表如何實(shí)現(xiàn)集合Set復(fù)雜度分析

2.1 探究鏈表情況下的n與二叉搜索樹(shù)的h的關(guān)系

Java基于二分搜索樹(shù)、鏈表如何實(shí)現(xiàn)集合Set復(fù)雜度分析

下面對(duì)n與h關(guān)系進(jìn)行推導(dǎo):

2.1.1 采用滿二叉樹(shù)的情況進(jìn)行分析(最優(yōu)情況)

采用滿二叉樹(shù)(每個(gè)節(jié)點(diǎn)都有左右節(jié)點(diǎn),除了葉子節(jié)點(diǎn))來(lái)進(jìn)行分析的原因?yàn)闈M二叉樹(shù)是一種極端情況,如下圖:

Java基于二分搜索樹(shù)、鏈表如何實(shí)現(xiàn)集合Set復(fù)雜度分析

從上圖中關(guān)于h層總共有多少個(gè)節(jié)點(diǎn)有如下推導(dǎo):

Java基于二分搜索樹(shù)、鏈表如何實(shí)現(xiàn)集合Set復(fù)雜度分析

假設(shè)節(jié)點(diǎn)個(gè)數(shù)為n個(gè)則有如下關(guān)系:

Java基于二分搜索樹(shù)、鏈表如何實(shí)現(xiàn)集合Set復(fù)雜度分析

針對(duì)都是log級(jí)別的關(guān)系,底數(shù)是多少不影響它是log級(jí)別的則有:

Java基于二分搜索樹(shù)、鏈表如何實(shí)現(xiàn)集合Set復(fù)雜度分析

2.1.2 單個(gè)孩子情況----二叉搜索樹(shù)最壞情況(節(jié)點(diǎn)數(shù)等于其高度)

比如:下面這種二叉搜索樹(shù)

Java基于二分搜索樹(shù)、鏈表如何實(shí)現(xiàn)集合Set復(fù)雜度分析

對(duì)于這種只有單個(gè)孩子的情況,此時(shí)二叉搜索樹(shù)退化成了鏈表,此時(shí)的時(shí)間復(fù)雜度為O(n)。

2.2 兩種集合復(fù)雜度統(tǒng)計(jì)

Java基于二分搜索樹(shù)、鏈表如何實(shí)現(xiàn)集合Set復(fù)雜度分析

2.2.1 logn和n的差距

Java基于二分搜索樹(shù)、鏈表如何實(shí)現(xiàn)集合Set復(fù)雜度分析

java基本數(shù)據(jù)類(lèi)型有哪些

Java的基本數(shù)據(jù)類(lèi)型分為:1、整數(shù)類(lèi)型,用來(lái)表示整數(shù)的數(shù)據(jù)類(lèi)型。2、浮點(diǎn)類(lèi)型,用來(lái)表示小數(shù)的數(shù)據(jù)類(lèi)型。3、字符類(lèi)型,字符類(lèi)型的關(guān)鍵字是“char”。4、布爾類(lèi)型,是表示邏輯值的基本數(shù)據(jù)類(lèi)型。

看完了這篇文章,相信你對(duì)“Java基于二分搜索樹(shù)、鏈表如何實(shí)現(xiàn)集合Set復(fù)雜度分析”有了一定的了解,如果想了解更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)網(wǎng)站建設(shè)公司行業(yè)資訊頻道,感謝各位的閱讀!

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)建站aaarwkj.com,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專(zhuān)為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。

網(wǎng)站名稱(chēng):Java基于二分搜索樹(shù)、鏈表如何實(shí)現(xiàn)集合Set復(fù)雜度分析-創(chuàng)新互聯(lián)
當(dāng)前鏈接:http://aaarwkj.com/article48/csoohp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供商城網(wǎng)站、Google網(wǎng)站營(yíng)銷(xiāo)、面包屑導(dǎo)航、網(wǎng)站內(nèi)鏈、企業(yè)建站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

商城網(wǎng)站建設(shè)
久久国产精品成人av| 男人的天堂成人午夜视频| 青青草原高清在线观看| 亚洲国产第一av导航| 日本一区欧美二区精品| 亚洲不卡高清一区二区三区| 少妇高潮一区二区三区在线| 亚洲精品免费一区二区三区| 片子免费毛片日韩不卡一区| 日韩欧美一区二区免费| av色剧情在线免费观看| 2020中文字字幕在线不卡| 国产国产成年年人免费看片| 91麻豆亚洲国产成人久久精品| 少妇按摩高潮呻吟av| 精品熟女少妇av免费久久野外| 国产精品国产精品无卡区| 婷婷国产综合一区二区三区| 国产免费一级av剧情| 久久精品久久精品欧美大片| 成年人免费观看黄色片| 门国产av一区二区三区| 日韩精品成人区中文字幕| 自偷自拍在线免费观看| 日韩久久精品免费视频| 中文字幕乱码亚洲影视| 日本少妇一区二区99| 说中文字幕的黄色大网站| 色吊丝二区三区中文字幕| 国产夫妻一区二区三区| 未满十八禁止观看免费| 国产av一区最新精品麻豆| av一区二区三区高潮| 中文字幕在线五月婷婷| 国产精品久久一国产精品| 中文字幕乱码亚洲影视| 国产三级视频在线2022| 亚洲av成人在线资源| 一区二区中文字幕日本韩国| 日韩x级av免费在线观看| 天堂在线精品亚洲综合网|