網站首頁 編程語言 正文
題目描述
輸入一個長度為 n 的鏈表,設鏈表中的元素的值為 ai ,返回該鏈表中倒數第k個節點。
如果該鏈表長度小于k,請返回一個長度為 0 的鏈表。
數據范圍:0<=n<=10^5,0<=ai<=10^9,0<=k<=10^9
要求:空間復雜度O(n),時間復雜度O(n)
進階:空間復雜度O(1),時間復雜度O(n)
例如輸入{1,2,3,4,5},2時,對應的鏈表結構如下圖所示:
其中藍色部分為該鏈表的最后2個結點,所以返回倒數第2個結點(也即結點值為4的結點)即可,系統會打印后面所有的節點來比較。
示例
輸入:
{1,2,3,4,5},2
返回值:
{4,5}
說明:
返回倒數第2個節點4,系統會打印后面所有的節點來比較。
解題思路
本題考察數據結構鏈表的使用。本題常用兩種思路,一種是比較基礎的,就是用容器把鏈表指針依次存儲,輸出倒數第k個即可,這樣空間復雜度為O(n);另一種進階解法,快慢指針法,讓快指針先走k步,當它走到頭時,此時慢指針的位置就是倒數第k個結點。
測試代碼為快慢指針法,容器法比較簡單就不寫了。
測試代碼
/** * struct ListNode { * int val; * struct ListNode *next; * ListNode(int x) : val(x), next(nullptr) {} * }; */ class Solution { public: /** * 代碼中的類名、方法名、參數名已經指定,請勿修改,直接返回方法規定的值即可 * * * @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; } // 當快指針走完時,慢指針的位置就是倒數第k個結點 while(fast != NULL) { fast = fast->next; slow = slow->next; } return slow; } };
補充
第二種實現方法:
/** * struct ListNode { * int val; * struct ListNode *next; * ListNode(int x) : val(x), next(nullptr) {} * }; */ class Solution { public: /** * 代碼中的類名、方法名、參數名已經指定,請勿修改,直接返回方法規定的值即可 * * * @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; } };
原文鏈接:https://blog.csdn.net/zhaitianbao/article/details/121929835
相關推薦
- 2022-07-13 redis搭建哨兵集群的實現步驟_Redis
- 2022-04-01 使用lsof命令恢復已刪除文件(正在使用的文件)
- 2022-09-15 React手寫一個手風琴組件示例_React
- 2022-04-16 C語言數據結構之二分法查找詳解_C 語言
- 2022-10-15 python中mpi4py的所有基礎使用案例詳解_python
- 2023-02-07 Android?Service完整實現流程分析_Android
- 2022-02-03 騰訊云服務器連接失敗,啟動報錯:A start job is running for /etc/rc
- 2022-01-05 解決:啟動Redis報錯:`Could not create server TCP listenin
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支