国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術(shù)文章
文章詳情頁

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

瀏覽:6日期:2022-09-03 15:46:00

本文實(shí)例講述了Java基于二分搜索樹、鏈表的實(shí)現(xiàn)的集合Set復(fù)雜度分析。分享給大家供大家參考,具體如下:

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

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

//創(chuàng)建一個測試方法 Set<String> set:他們可以是實(shí)現(xiàn)了該接口的LinkedListSet和BSTSet對象 private static double testSet(Set<String> set, String filename) { //計算開始時間 long startTime = System.nanoTime(); System.out.println('Pride and Prejudice'); //新建一個ArrayList存放單詞 ArrayList<String> words1 = new ArrayList<>(); //通過這個方法將書中所以單詞存入word1中 FileOperation.readFile(filename, words1); System.out.println('Total words : ' + words1.size()); //增強(qiáng)for循環(huán),定一個字符串word去遍歷words //底層的話會把ArrayList words1中的值一個一個的賦值給word for (String word : words1) set.add(word);//不添加重復(fù)元素 System.out.println('Total different words : ' + set.getSize()); //計算結(jié)束時間 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í)現(xiàn)的集合Set復(fù)雜度分析實(shí)例詳解

集合的時間復(fù)雜度分析:1.鏈表情況

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

2.二叉搜索樹的情況

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

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

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

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

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

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

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

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

采用滿二叉樹(每個節(jié)點(diǎn)都有左右節(jié)點(diǎn),除了葉子節(jié)點(diǎn))來進(jìn)行分析的原因為滿二叉樹是一種極端情況,如下圖:

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

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

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

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

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

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

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

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

比如:下面這種二叉搜索樹

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

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

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

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

2.2.1 logn和n的差距

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

推薦是最好的支持,關(guān)注是最大的鼓勵。親愛的朋友,很榮幸在園子里遇到您。

本節(jié)涉及的源碼地址為https://github.com/FelixBin/dataStructure/tree/master/src/SetPart

更多關(guān)于java算法相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Java數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Java操作DOM節(jié)點(diǎn)技巧總結(jié)》、《Java文件與目錄操作技巧匯總》和《Java緩存操作技巧匯總》

希望本文所述對大家java程序設(shè)計有所幫助。

標(biāo)簽: Java
相關(guān)文章:
主站蜘蛛池模板: 在线视频久 | 亚洲国产欧美视频 | 成 人色 网 站 欧美大片在线观看 | 亚洲欧美日韩在线播放 | 欧美一区二区三区播放 | 久久的精品99精品66 | 欧美视频一区二区三区 | 欧美特级午夜一区二区三区 | 欧美成a人免费观看久久 | 成年人免费软件 | 99视频在线免费观看 | 四虎免费大片aⅴ入口 | 99一区二区三区 | 毛片在线高清免费观看 | 美女成人网 | 国产精品欧美日韩一区二区 | 日本一区二区三区免费视频 | 成人a一级毛片免费看 | 国产专区中文字幕 | 最近中文字幕在线 | 中文 | 一级女性全黄久久生活片免费 | 国产视频二 | 亚洲热视频 | 成人性版蝴蝶影院污 | 国产精品国色综合久久 | 性生i活一级一片 | 国产99视频在线 | 国产一级毛片网站 | 成人看片黄a毛片 | 动漫一级毛片 | 男女性高爱潮免费网站 | 亚洲国产另类久久久精品小说 | 美女张开腿黄网站免费国产 | 美女张开腿给人网站 | 国产在线爱做人成小视频 | 亚洲欧美视频在线播放 | 欧美性欲视频 | 亚洲操综合 | 日本手机看片 | 伊人狠狠丁香婷婷综合色 | 久久r视频 |