C++實現(xiàn)單鏈表刪除倒數(shù)第k個節(jié)點的方法
本文實例講述了C++實現(xiàn)單鏈表刪除倒數(shù)第k個節(jié)點的方法。分享給大家供大家參考,具體如下:
題目:
刪除單鏈表中倒數(shù)第k個節(jié)點
解題思路及算法代碼:
標(biāo)尺法,定義兩個指針指向鏈表頭結(jié)點,先讓一個走k步,然后兩個指針同時開始走,當(dāng)先走的指針走到末尾時,后走的指針指向的結(jié)點就是需要刪除的結(jié)點。
單鏈表結(jié)構(gòu)定義:
typedef struct Node
{
int data;
struct Node* next;
}node, *pLinkedList;
刪除倒數(shù)第K結(jié)點操作代碼:
//head表示頭結(jié)點
Node* removeLastKthNode(pLinkedList head, int k)
{
if (NULL == head->next || k < 1)
return head;
pLinkedList cur = head; //1號指針
pLinkedList ret = head; //2號指針,指向待刪除節(jié)點
pLinkedList pre = NULL; //pdel待刪除節(jié)點的前一個節(jié)點
/*
head 1 2 3 4 5
cur
ret
*/
while (k > 0 && cur != NULL)
{
k--;
cur = cur->next;
}
//當(dāng)鏈表走到終點時,k仍然大于0,可知k值大于鏈表長度
if (k > 0 && cur == NULL)
{
cout << "k值大于鏈表長度" << endl;
return head;
}
//k == 0時,1號指針和2號指針同時走,ret即為待刪除的節(jié)點
if (k == 0)
{
while (cur != NULL)
{
pre = ret;
cur = cur->next;
ret = ret->next;
}
/*k = 2時
head 1 2 3 4 5 NULL
pre ret cur
即要求刪除ret節(jié)點
*/
pre->next = ret->next;
free(ret);
ret = NULL;
return head;
}
}
希望本文所述對大家C++程序設(shè)計有所幫助。
相關(guān)文章
Qt物聯(lián)網(wǎng)管理平臺之實現(xiàn)告警短信轉(zhuǎn)發(fā)
系統(tǒng)在運行過程中,會實時采集設(shè)備的數(shù)據(jù),當(dāng)采集到的數(shù)據(jù)發(fā)生報警后,可以將報警信息以短信的形式發(fā)送給指定的管理員。本文將利用Qt實現(xiàn)告警短信轉(zhuǎn)發(fā),感興趣的可以嘗試一下2022-07-07
C語言 ffmpeg與sdl實現(xiàn)播放視頻同時同步時鐘詳解
使用ffmpeg和sdl實現(xiàn)播放視頻后,需要再實現(xiàn)時鐘同步才能正常的播放視頻,尤其是有音頻的情況,我們通常需要將視頻同步到音頻來確保音畫同步2022-09-09
C++實現(xiàn)LeetCode(112.二叉樹的路徑和)
這篇文章主要介紹了C++實現(xiàn)LeetCode(112.二叉樹的路徑和),本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07

