欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C++解決輸出鏈表中倒數(shù)k個結(jié)點的問題

 更新時間:2021年12月15日 08:46:03   作者:翟天保Steven  
這篇文章主要給大家介紹了關(guān)于如何利用C++解決輸出鏈表中倒數(shù)k個結(jié)點的問題,文中通過實例代碼介紹的非常詳細,對大家學習或者使用C++具有一定的參考學習價值,需要的朋友可以參考下

題目描述

輸入一個長度為 n 的鏈表,設(shè)鏈表中的元素的值為 ai ,返回該鏈表中倒數(shù)第k個節(jié)點。

如果該鏈表長度小于k,請返回一個長度為 0 的鏈表。

數(shù)據(jù)范圍:0<=n<=10^5,0<=ai<=10^9,0<=k<=10^9

要求:空間復(fù)雜度O(n),時間復(fù)雜度O(n)

進階:空間復(fù)雜度O(1),時間復(fù)雜度O(n)

例如輸入{1,2,3,4,5},2時,對應(yīng)的鏈表結(jié)構(gòu)如下圖所示:

其中藍色部分為該鏈表的最后2個結(jié)點,所以返回倒數(shù)第2個結(jié)點(也即結(jié)點值為4的結(jié)點)即可,系統(tǒng)會打印后面所有的節(jié)點來比較。

示例

輸入:

{1,2,3,4,5},2

返回值:

{4,5}

說明:

返回倒數(shù)第2個節(jié)點4,系統(tǒng)會打印后面所有的節(jié)點來比較。

解題思路

本題考察數(shù)據(jù)結(jié)構(gòu)鏈表的使用。本題常用兩種思路,一種是比較基礎(chǔ)的,就是用容器把鏈表指針依次存儲,輸出倒數(shù)第k個即可,這樣空間復(fù)雜度為O(n);另一種進階解法,快慢指針法,讓快指針先走k步,當它走到頭時,此時慢指針的位置就是倒數(shù)第k個結(jié)點。

測試代碼為快慢指針法,容器法比較簡單就不寫了。

測試代碼

/**
 * struct ListNode {
 *	int val;
 *	struct ListNode *next;
 *	ListNode(int x) : val(x), next(nullptr) {}
 * };
 */
class Solution {
public:
    /**
     * 代碼中的類名、方法名、參數(shù)名已經(jīng)指定,請勿修改,直接返回方法規(guī)定的值即可
     *
     * 
     * @param pHead ListNode類 
     * @param k int整型 
     * @return ListNode類
     */
    ListNode* FindKthToTail(ListNode* pHead, int k) {
        // 空鏈表直接返回
        if(pHead == NULL)
            return pHead;
        // 快慢指針
        ListNode *fast = pHead;
        ListNode *slow = pHead;
        // 讓快指針先走k步
        while(k--)
        {
            if(fast == NULL)
                return NULL;
            fast = fast->next;
        }
        // 當快指針走完時,慢指針的位置就是倒數(shù)第k個結(jié)點
        while(fast != NULL)
        {
            fast = fast->next;
            slow = slow->next;
        }
        return slow;
    }
};

補充

第二種實現(xiàn)方法:

/**
 * struct ListNode {
 *	int val;
 *	struct ListNode *next;
 *	ListNode(int x) : val(x), next(nullptr) {}
 * };
 */
class Solution {
public:
    /**
     * 代碼中的類名、方法名、參數(shù)名已經(jīng)指定,請勿修改,直接返回方法規(guī)定的值即可
     *
     * 
     * @param pHead ListNode類 
     * @param k int整型 
     * @return ListNode類
     */
    ListNode* FindKthToTail(ListNode* pHead, int k) {
        // write code here
        ListNode* p=pHead;
        ListNode* q=pHead;
        if(pHead==NULL)return NULL;
        while(k--)
        {
            if(q==NULL)return NULL;
            q=q->next;
            
            //k--;
        }
        //if(q==NULL)return pHead;
        while(q)
        {
            p=p->next;
            q=q->next;
        }
        return p;
    }
};

到此這篇關(guān)于C++解決輸出鏈表中倒數(shù)k個結(jié)點的問題的文章就介紹到這了,更多相關(guān)C++輸出鏈表中倒數(shù)k個結(jié)點內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評論