面試題22 鍊錶中倒數第k個節點

2021-10-02 22:05:46 字數 498 閱讀 4214

//假如單鏈表有n個節點,倒數第k個節點,即為n-k+1;

//利用雙指標進行判斷,前指標走到k-1的位置,即開頭的k-1位置,然後讓後指標跟前指標一起走

//當前指標到達尾部的時候,後指標剛好到達倒數第k個節點

#include

struct listnode

;//假如單鏈表有n個節點,倒數第k個節點,即為n-k+1;

//利用雙指標進行判斷,前指標走到k-1的位置,即開頭的k-1位置,然後讓後指標跟前指標一起走

//當前指標到達尾部的時候,後指標剛好到達倒數第k個節點

listnode*

findkthtotail

(listnode* phead,

int k)

pbehind = pahead;

while

(pahead-

>m_next)

return pbehind;

}

面試題22 鍊錶中倒數第K個節點

面試題22 輸入乙個鍊錶,輸出該鍊錶中倒數第k個結點。definition for singly linked list.struct listnode class solution listnode phead head listnode pbehind nullptr 前面的指標先走k 1步時,...

面試題22 鍊錶中倒數第k個節點

輸入乙個鍊錶,輸出該鍊錶中倒數第k個節點。為了符合大多數人的習慣,本題從1開始計數,即鍊錶的尾節點是倒數第1個節點。例如,乙個鍊錶有6個節點,從頭節點開始,它們的值依次是1 2 3 4 5 6。這個鍊錶的倒數第3個節點是值為4的節點。示例 給定乙個鍊錶 1 2 3 4 5,和 k 2.返回鍊錶 4 ...

劍指面試題22 鍊錶中倒數第k個節點

題目 輸入乙個鍊錶,輸出該鍊錶中倒數第k個節點。為了符合大多數人的習慣,本題從1開始計數,即鍊錶的尾節點是倒數第1個節點。例如,乙個鍊錶有6個節點,從頭節點開始,它們的值依次是1 2 3 4 5 6。這個鍊錶的倒數第3個節點是值為4的節點。第一種實現 遍歷放在列表中,但是會增加空間複雜度 codin...