題目描述:?jiǎn)捂湵聿檎业箶?shù)第k個(gè)節(jié)點(diǎn)
創(chuàng)新互聯(lián)建站主營(yíng)鹽邊網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營(yíng)網(wǎng)站建設(shè)方案,重慶APP開發(fā),鹽邊h5成都微信小程序搭建,鹽邊網(wǎng)站營(yíng)銷推廣歡迎鹽邊等地區(qū)企業(yè)咨詢分析:?jiǎn)捂湵硎且粋€(gè)單向的鏈?zhǔn)浇Y(jié)構(gòu),所以不可能從鏈表尾部向前找第k個(gè)結(jié)點(diǎn),因此只能想辦法從鏈表的頭部開始找。
假設(shè)一個(gè)給定一個(gè)鏈表,長(zhǎng)度為 6,現(xiàn)在查找倒數(shù)第 2 個(gè)結(jié)點(diǎn):

給定兩個(gè)指針, fast 和 slow 開始都讓他們指向頭結(jié)點(diǎn)

首先,讓 fast 指針先走到正數(shù)第 k 個(gè)結(jié)點(diǎn),也就是走 k-1 步,這里 k=2,所以先讓 fast 走1步

這時(shí)讓 slow 指針跟著 fast 指針一塊走,直到 fast 指針走到最后一個(gè)節(jié)點(diǎn)(注意:這里是最后一個(gè)節(jié)點(diǎn),而不是空節(jié)點(diǎn)),此時(shí) slow 指針?biāo)赶虻墓?jié)點(diǎn)就是我們要找的倒數(shù)第 k 個(gè)結(jié)點(diǎn)了

當(dāng)然,這里只是大致的思想,具體的很多細(xì)節(jié)問題(比如: k值大于鏈表的長(zhǎng)度,k = 0 的情況等等),需要自己處理。
主要代碼如下:
ListNode* FindKthToTail(ListNode* pListHead, unsigned int k)
{
if(pListHead == NULL || k == 0) //一些異常情況
{
return NULL;
}
ListNode* fast = pListHead;
ListNode* slow = pListHead;
while(fast && --k) //這里一定要先自減,因?yàn)閮蓚€(gè)指針開始都指向頭結(jié)點(diǎn)
{
fast = fast->next;
}
if(fast == NULL) //即沒找到的情況
{
return NULL;
}
if(k == 0)
{
while(fast->next != NULL)
{
fast = fast->next;
slow = slow ->next;
}
}
return slow;
}創(chuàng)新互聯(lián)www.cdcxhl.cn,專業(yè)提供香港、美國(guó)云服務(wù)器,動(dòng)態(tài)BGP最優(yōu)骨干路由自動(dòng)選擇,持續(xù)穩(wěn)定高效的網(wǎng)絡(luò)助力業(yè)務(wù)部署。公司持有工信部辦法的idc、isp許可證, 機(jī)房獨(dú)有T級(jí)流量清洗系統(tǒng)配攻擊溯源,準(zhǔn)確進(jìn)行流量調(diào)度,確保服務(wù)器高可用性。佳節(jié)活動(dòng)現(xiàn)已開啟,新人活動(dòng)云服務(wù)器買多久送多久。
當(dāng)前文章:單鏈表查找倒數(shù)第k個(gè)節(jié)點(diǎn)-創(chuàng)新互聯(lián)
網(wǎng)站地址:http://chinadenli.net/article22/cohcjc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站改版、響應(yīng)式網(wǎng)站、商城網(wǎng)站、云服務(wù)器、企業(yè)網(wǎng)站制作、定制網(wǎng)站
聲明:本網(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í)需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容