版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
第12章常用算法與Collections類2024/11/912024/11/922024/11/93Collections類是Object類的一個(gè)直接子類(注意Collections比Collection多了一個(gè)字母s),該類封裝了一系列算法,例如,二分查找,排序、洗牌等算法,這些算法可用于List,Queue、Set。需要注意的是Collections是類,Collection是接口,Collections類沒有實(shí)現(xiàn)Collection接口.12.1排序2024/11/94
2024/11/9512.1排序例子1Score.java例子1中的主類Example12_1使用Collections類的sort()方法排序(升序)一個(gè)鏈表,首先按鏈表中的對象實(shí)現(xiàn)的Comparable接口給出的比較器排序鏈表,然后再指定新的比較器排序鏈表。Example12_1.java12.2二分查找2024/11/96publicstaticintbinarySearch(List<?extendsT>list,Tkey)查找對象key是否在升序的list中(list中的對象按自然序排序),如果key在list中,方法返回key在list中的索引位置(索引位置從0開始),否則返回一個(gè)負(fù)數(shù)。publicstaticintbinarySearch(List<?extendsT>list,Tkey,Comparator<?superT>c)查找對象key是否在升序的list中(list的元素按比較器c排序),如果key在list中,方法返回key在list中的索引位置(索引位置從0開始),否則返回一個(gè)負(fù)數(shù)。注意,排序使用的比較器的算法需要和該方法使用的比較器c的算法相同。2024/11/9712.2二分查找例子2FindWords.java例子2中的FindWords類的booleanfindWords(Stringstr,Stringkey)方法使用二分法判斷單詞key是否在str中。Example12_2.java12.3反轉(zhuǎn)與旋轉(zhuǎn)2024/11/98publicstaticvoidreverse(List<?>list)反轉(zhuǎn)list中元素的順序.publicstaticvoidrotate(List<?>list,intdistance)把list向右(distance是正整數(shù))或向左(distance是負(fù)整數(shù))旋轉(zhuǎn)distance個(gè)索引位置。例如,list節(jié)點(diǎn)中的對象依次是[a,b,c,d,e],如果執(zhí)行Colections.rotate(list,1),那么list節(jié)點(diǎn)中的對象依次是[e,a,b,c,d],如果執(zhí)行Colections.rotate(list,-2),那么list節(jié)點(diǎn)中的對象依次是[cdeab]。2024/11/9912.3反轉(zhuǎn)與旋轉(zhuǎn)例子3LeaveOne.javaWordReverse.java例子3中的LeaveOne類的leaveByRotate(LinkedList<Integer>list)方法通過旋轉(zhuǎn)鏈表,解決約瑟夫問題:把list向左旋轉(zhuǎn)2個(gè)索引位置,即可確定出退出圈中的人,理由是,此刻鏈表頭節(jié)點(diǎn)就是數(shù)到的第3個(gè)人,即要出圈的人。例子3的WordRevers類的isReverse(Stringword)方法判斷word是否是回文單詞(回文單詞和它的反轉(zhuǎn)相同)。建議讀者把這里的例子3和第4章的例子9做一個(gè)比較,體會(huì)使用旋轉(zhuǎn)list解決約瑟夫問題,能讓代碼更加簡練。Example12_3.java12.4洗牌2024/11/910我們曾在第4章的4.10節(jié),講解過洗牌算法,即Fisher-Yates洗牌算法。Collections類將Fisher-Yates洗牌算法封裝在下列方法中:publicstaticvoidshuffle(List<?>list)使用Fisher-Yates洗牌算法排列l(wèi)ist。2024/11/91112.4洗牌例子4例子4的主類Example12_4使用Collectiones類提供的Fisher-Yates洗牌算法演示洗牌過程。Example12_4.java12.5最大與最小2024/11/912publicstaticTmax(Collection<?extendsT>coll)按coll元素的自然序(元素實(shí)現(xiàn)Comparable接口中的比較器給出的大小順序),返回coll中的最大值。publicstaticTmin(Collection<?extendsT>coll)按coll元素的自然序,返回coll中的最小值。publicstaticTmax(Collection<?extendsT>coll,Comparator<?superT>comp)
按comp比較器,返回coll中的最大值。publicstaticTmin(Collection<?extendsT>coll,,Comparator<?superT>comp)按comp比較器,返回coll中的最小值。2024/11/91312.5最大與最小例子5Example12_5.java例子5中的主類Example12_5求集合中的最大值和最小值。12.6頻率2024/11/914publicstaticintfrequency(Collection<?>c,Objectobj)返回c中與指定對象obj相等的元素的數(shù)量。我們曾在第10章的例子5中,使用散列表統(tǒng)計(jì)文本文件中單詞出現(xiàn)的次數(shù)和頻率。下面的例子6使用intfrequency(Collection<?>c,Objectobj)方法統(tǒng)計(jì)文本文件中單詞或漢字出現(xiàn)的次數(shù)和頻率。2024/11/91512.5最大與最小例子6Example12_6.java例子6中的FrequencyEnglish類將英文組成的文本文件中的單詞存放在一個(gè)集合中,便于統(tǒng)計(jì)出不相同的單詞的總數(shù),把單詞存放在一個(gè)鏈表中,便于統(tǒng)計(jì)每個(gè)單詞出現(xiàn)的次數(shù),
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2024年中國加氫精制阻垢劑市場調(diào)查研究報(bào)告
- 2024年中國全自動(dòng)噴霧機(jī)市場調(diào)查研究報(bào)告
- 2025至2030年中國牛仔七分褲行業(yè)投資前景及策略咨詢研究報(bào)告
- 2025至2030年中國異形螺栓行業(yè)投資前景及策略咨詢研究報(bào)告
- 城市防洪駁岸工程施工合同
- 2024年中國美容棉巾市場調(diào)查研究報(bào)告
- 2024年中國社區(qū)衛(wèi)生服務(wù)管理系統(tǒng)市場調(diào)查研究報(bào)告
- 2024年中國電鍍摩托車后視鏡市場調(diào)查研究報(bào)告
- 2024年中國甲哌鎓水劑市場調(diào)查研究報(bào)告
- 2024年中國護(hù)針板市場調(diào)查研究報(bào)告
- 專升本英語寫作專題講解課件
- 干預(yù)策略患兒床頭抬高影響
- 平安保險(xiǎn)授權(quán)委托書
- 電力增容改造技術(shù)標(biāo)模板
- 血培養(yǎng)采集的方法及注意事項(xiàng)
- 梁靜茹《勇氣》的歌詞
- 國家開放大學(xué)02150-計(jì)算機(jī)網(wǎng)絡(luò)(本)期末復(fù)習(xí)題及參考答案
- 國開2023年春《理工英語3》機(jī)考網(wǎng)考期末復(fù)習(xí)資料參考答案
- 員工安全培訓(xùn)教育制度
- 譯林版一年級英語上冊期末試卷
- 阿爾瓦·阿爾托
評論
0/150
提交評論