下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、2425;快慢指針技巧匯總雙指針技巧可以分為兩類:一類是【快慢指針】、一類是【左右指針】、快慢指針快慢指針一般初始化指向鏈表頭結(jié)點(diǎn)head,前進(jìn)時(shí)快指針fast在前,慢指針slow在后,巧妙解決鏈表中的一些問題。1、判斷鏈表中是否有環(huán)經(jīng)典解法就是用兩個(gè)指針,一個(gè)每次前進(jìn)兩步,一個(gè)每次前進(jìn)一步。如果不含有環(huán),跑得快的那個(gè)指針最終會(huì)遇到null,說明鏈表不含環(huán);如果含有環(huán),快指針最終會(huì)超慢指針一圈,和慢指針相遇,說明鏈表含有環(huán)。*1/*Definitionforsingly-linkedlist.*structListNode*intval;*ListNode*next;*ListNode(int
2、x):val(x),next(NULL)*;*/classSolutionpublic:boolhasCycle(ListNode*head)ListNode*slow,*fast;slow=head;fast=head;while(fast!=NULL&fast-next!=NULL)fast=fast-next-next;slow=slow-next;17if(fast=slow)returntrue;returnfalse;2、返回環(huán)的起始位置第一次相遇時(shí),假設(shè)慢指針slow走了k步,那么快指針fast定走了2k步,也就是說比slow多走了k步(也就是環(huán)的長(zhǎng)度)。設(shè)相遇點(diǎn)距環(huán)的起點(diǎn)的距離
3、為m,那么環(huán)的起點(diǎn)距頭結(jié)點(diǎn)head的距離為k-m,也就是說如果從head前進(jìn)k-m步就能到達(dá)環(huán)起點(diǎn)。巧的是,如果從相遇點(diǎn)繼續(xù)前進(jìn)k-m步,也恰好到達(dá)環(huán)起點(diǎn)。classSolutionpublic:ListNode*detectCycle(ListNode*head)ListNode*slow,*fast;boolhascycle=false;/標(biāo)記鏈表中是否有環(huán)slow=head;fast=head;while(fast!=NULL&fast-next!=NULL)fast=fast-next-next;slow=slow-next;if(fast=slow)hascycle=true;bre
4、ak;if(hascycle)slow=head;while(slow!=fast)slow=slow-next;fast=fast-next;returnslow;elsereturnNULL;173、尋找鏈表的中點(diǎn)快指針一次前進(jìn)兩步,慢指針一次前進(jìn)一步,當(dāng)快指針到達(dá)鏈表盡頭時(shí),慢指針就處于鏈表的中間位置。classSolutionpublic:ListNode*middleNode(ListNode*head)ListNode*slow,*fast;slow=head;fast=head;while(fast!=NULL&fast-next!=NULL)fast=fast-next-nex
5、t;slow=slow-next;returnslow;4、尋找鏈表的倒數(shù)第k個(gè)元素我們的思路還是使用快慢指針,讓快指針先走k步,然后快慢指針開始同速前進(jìn)。這樣當(dāng)快指針走到鏈表末尾null時(shí),慢指針?biāo)诘奈恢镁褪堑箶?shù)第k個(gè)鏈表節(jié)點(diǎn).*1/*Definitionforsingly-linkedlist.structListNodeintval;ListNode*next;ListNode(intx):val(x),next(NULL);*/classSolutionpublic:ListNode*getKthFromEnd(ListNode*head,intk)ListNode*slow,*fa
6、st;slow=head;fast=head;while(k-)fast=fast-next;while(fast!=NULL)fast=fast-next;slow=slow-next;returnslow;二、左右扌旨針左右指針在數(shù)組中實(shí)際是指兩個(gè)索引值,一般初始化為left=0,right=nums.length-1。1、二分查找(普通二分)intbinarySerarch(vector&nums,inttarget)intleft=0;intright=nums.size()-1;while(left1;if(numsmid=target)returnmid;elseif(numsmi
7、dtarget)left=mid+1;elseright=mid-1;return-1;2、兩數(shù)之和如果數(shù)組有序,就應(yīng)該想到雙指針技巧。這道題的解法有點(diǎn)類似二分查找,通過調(diào)節(jié)left和right可以調(diào)整sum的大小:inttwoSum(vector&nums,inttarget)intleft=0;intright=nums.size()-1;while(leftright)intnum=numsleft+numsright;67891011if(num=target)returnleft,right;elseright-;elseif(numtarget)left+;return;只3、反轉(zhuǎn)數(shù)組voidreverse(intnums)intleft=0;intright=nums.length-1;while(leftright)/swap(numsleft,numsright)inttemp=numsleft;numslef
溫馨提示
- 1. 本站所有資源如無(wú)特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 清遠(yuǎn)2025年廣東清遠(yuǎn)市清城區(qū)委統(tǒng)一戰(zhàn)線工作部招聘專項(xiàng)工作聘員筆試歷年參考題庫(kù)附帶答案詳解
- 榆林2025年陜西榆林市靖邊縣事業(yè)單位招聘教師80人筆試歷年參考題庫(kù)附帶答案詳解
- 無(wú)錫2025年江蘇無(wú)錫市文物考古研究所招聘事業(yè)編制專業(yè)人才7人筆試歷年參考題庫(kù)附帶答案詳解
- 徐州2025年江蘇省徐州經(jīng)貿(mào)高等職業(yè)學(xué)校招聘教師15人筆試歷年參考題庫(kù)附帶答案詳解
- 寧波浙江寧波市海曙區(qū)招聘屠宰檢疫輔助員5人筆試歷年參考題庫(kù)附帶答案詳解
- 職業(yè)人群聽力健康檔案管理規(guī)范
- 南京2025年江蘇南京市秦淮區(qū)教育局所屬學(xué)校招聘高層次人才6人筆試歷年參考題庫(kù)附帶答案詳解
- 東莞廣東東莞市公安局東坑分局警務(wù)輔助人員招聘31人筆試歷年參考題庫(kù)附帶答案詳解
- 中國(guó)3-丁烯-1-醇行業(yè)市場(chǎng)運(yùn)行態(tài)勢(shì)及發(fā)展趨勢(shì)預(yù)測(cè)報(bào)告-智研咨詢發(fā)布
- 耳鼻喉科團(tuán)隊(duì)急癥模擬中的領(lǐng)導(dǎo)力培養(yǎng)策略-1
- 2025年工廠三級(jí)安全教育考試卷含答案
- 2026年上海理工大學(xué)單招職業(yè)適應(yīng)性測(cè)試題庫(kù)附答案
- TCEC電力行業(yè)數(shù)據(jù)分類分級(jí)規(guī)范-2024
- 建設(shè)用地報(bào)批培訓(xùn)課件
- 駱駝的養(yǎng)殖技術(shù)與常見病防治
- 化肥產(chǎn)品生產(chǎn)許可證實(shí)施細(xì)則(一)(復(fù)肥產(chǎn)品部分)2025
- 2025至2030中國(guó)醫(yī)療收入周期管理軟件行業(yè)深度研究及發(fā)展前景投資評(píng)估分析
- 基層醫(yī)療資源下沉的實(shí)踐困境與解決路徑實(shí)踐研究
- 1101無(wú)菌檢查法:2020年版 VS 2025年版對(duì)比表
- 醫(yī)務(wù)科副科長(zhǎng)醫(yī)務(wù)人員調(diào)配工作方案
- 2025及未來(lái)5-10年高壓管匯項(xiàng)目投資價(jià)值市場(chǎng)數(shù)據(jù)分析報(bào)告
評(píng)論
0/150
提交評(píng)論