下載本文檔
版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(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在后,巧妙解決鏈表中的一些問(wèn)題。1、判斷鏈表中是否有環(huán)經(jīng)典解法就是用兩個(gè)指針,一個(gè)每次前進(jìn)兩步,一個(gè)每次前進(jìn)一步。如果不含有環(huán),跑得快的那個(gè)指針最終會(huì)遇到null,說(shuō)明鏈表不含環(huán);如果含有環(huán),快指針最終會(huì)超慢指針一圈,和慢指針相遇,說(shuō)明鏈表含有環(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步,也就是說(shuō)比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,也就是說(shuō)如果從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步,然后快慢指針開(kāi)始同速前進(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)類似二分查找,通過(guò)調(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ú)特殊說(shuō)明,都需要本地電腦安裝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ù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 福建師范大學(xué)《運(yùn)動(dòng)技能學(xué)習(xí)與控制》2021-2022學(xué)年第一學(xué)期期末試卷
- 福建師范大學(xué)《土壤地理學(xué)實(shí)驗(yàn)》2022-2023學(xué)年第一學(xué)期期末試卷
- 福建師范大學(xué)《數(shù)字信號(hào)處理應(yīng)用一》2022-2023學(xué)年第一學(xué)期期末試卷
- 福建師范大學(xué)《數(shù)學(xué)》2021-2022學(xué)年第一學(xué)期期末試卷
- 福建師范大學(xué)《基金管理學(xué)實(shí)驗(yàn)》2023-2024學(xué)年第一學(xué)期期末試卷
- 統(tǒng)編版八年級(jí)第一學(xué)期語(yǔ)文期中測(cè)試卷
- 電氣質(zhì)量驗(yàn)收規(guī)范考試題
- 教師教科研現(xiàn)狀與需求調(diào)查問(wèn)卷
- 7《請(qǐng)到我的家鄉(xiāng)來(lái)》第二課時(shí)(教學(xué)設(shè)計(jì))-部編版道德與法治三年級(jí)下冊(cè)
- (BZ1)中建西北院BIM標(biāo)準(zhǔn)
- 初級(jí)插花理論知識(shí)考核試題及答案
- 河南省洛陽(yáng)市《綜合能力測(cè)試》事業(yè)單位國(guó)考真題
- 法醫(yī)物證學(xué)第十二章血痕檢驗(yàn)1
- 智慧消防整體解決方案消防大數(shù)據(jù)一體化管理平臺(tái)解課件
- 國(guó)家自然科學(xué)基金申請(qǐng)經(jīng)驗(yàn)匯總課件
- 社會(huì)實(shí)踐鑒定表
- 2022版義務(wù)教育(化學(xué))課程標(biāo)準(zhǔn)(含2022年修訂部分)
- 公司吸煙管理規(guī)定范文
- 消毒記錄表(簡(jiǎn)單模板)
- 東北抗聯(lián)精神很實(shí)用-學(xué)習(xí)東北抗聯(lián)精神共24張課件
- 老舊小區(qū)改造施工組織詳細(xì)
評(píng)論
0/150
提交評(píng)論