網(wǎng)站首頁(yè) 編程語言 正文
大家好,今天和大家分享的是反轉(zhuǎn)鏈表的兩種方法,第一種是用泛型編程里面的STL,第二種是利用多個(gè)指針進(jìn)行操作,小孩子才做選擇,建議兩個(gè)都學(xué)。我們往下看:
一.使用vector容器
ps:該方法對(duì)內(nèi)存的需求較高,這是個(gè)缺點(diǎn),可以直接使用STL容器自帶的reverse進(jìn)行反轉(zhuǎn)(將vector容器內(nèi)的結(jié)點(diǎn)進(jìn)行反轉(zhuǎn),然后再用for循環(huán)將他串聯(lián)起來),實(shí)現(xiàn)起來相對(duì)容易,思路不太復(fù)雜。
請(qǐng)看以下代碼:
typedef struct Node
{
int val;
struct Node*next;
}ListNode;
class traverse {
public:
ListNode* ReverseList(ListNode* pHead) {
if (!pHead) return nullptr;
vector<ListNode*> v;
while (pHead) {
v.push_back(pHead);
pHead = pHead->next;
}
reverse(v.begin(), v.end()); // 反轉(zhuǎn)vector,也可以逆向遍歷
ListNode *head = v[0];
ListNode *cur = head;
for (int i=1; i<v.size(); ++i) { // 構(gòu)造鏈表
cur->next = v[i]; // 當(dāng)前節(jié)點(diǎn)的下一個(gè)指針指向下一個(gè)節(jié)點(diǎn)
cur = cur->next; // 當(dāng)前節(jié)點(diǎn)后移
}
cur->next = nullptr; // 切記最后一個(gè)節(jié)點(diǎn)的下一個(gè)指針指向nullptr
return head;
}
};
此方法的復(fù)雜度:
時(shí)間復(fù)雜度:O(n)
空間復(fù)雜度:O(n), 用了一個(gè)vector來存單鏈表
二.調(diào)整指針法
ps:此方法更加妥當(dāng),能得到更多人的青睞,很好的利用幾個(gè)指針的指向反轉(zhuǎn)一個(gè)鏈表。
初始化:3個(gè)指針
1)pre指針指向已經(jīng)反轉(zhuǎn)好的鏈表的最后一個(gè)節(jié)點(diǎn),最開始沒有反轉(zhuǎn),所以指向nullptr
2)cur指針指向待反轉(zhuǎn)鏈表的第一個(gè)節(jié)點(diǎn),最開始第一個(gè)節(jié)點(diǎn)待反轉(zhuǎn),所以指向head
3)nex指針指向待反轉(zhuǎn)鏈表的第二個(gè)節(jié)點(diǎn),目的是保存鏈表,因?yàn)閏ur改變指向后,后面的鏈表則失效了,所以需要保存
接下來,循環(huán)執(zhí)行以下三個(gè)操作
1)nex = cur->next, 保存作用
2)cur->next = pre 未反轉(zhuǎn)鏈表的第一個(gè)節(jié)點(diǎn)的下個(gè)指針指向已反轉(zhuǎn)鏈表的最后一個(gè)節(jié)點(diǎn)
3)pre = cur, cur = nex; 指針后移,操作下一個(gè)未反轉(zhuǎn)鏈表的第一個(gè)節(jié)點(diǎn)
循環(huán)條件,當(dāng)然是cur != nullptr
循環(huán)結(jié)束后,cur當(dāng)然為nullptr,所以返回pre,即為反轉(zhuǎn)后的頭結(jié)點(diǎn)
這里以1->2->3->4->5 舉例:
代碼如下:
class Solution {
public:
ListNode* ReverseList(ListNode* pHead) {
ListNode *pre = nullptr;
ListNode *cur = pHead;
ListNode *nex = nullptr; // 這里可以指向nullptr,循環(huán)里面要重新指向
while (cur) {
nex = cur->next;
cur->next = pre;
pre = cur;
cur = nex;
}
return pre;
}
};
此方法復(fù)雜度:
時(shí)間復(fù)雜度:O(n), 遍歷一次鏈表
空間復(fù)雜度:O(1)
總結(jié):要從易懂的角度來看,第一種不失是好的,使用STL,我現(xiàn)在才大一,我聽說一些面試是不允許使用STL這一內(nèi)容解體的。第二種方法很妙,復(fù)雜度是比較理想的,而且用到了靈魂指針的應(yīng)用。建議大家多琢磨一下第二種方法。
原文鏈接:https://blog.csdn.net/weixin_73233099/article/details/128940685
相關(guān)推薦
- 2022-05-10 torch.cuda.is_available()返回false最終解決方案
- 2022-02-22 使用Flex布局實(shí)現(xiàn)頭部固定,內(nèi)容區(qū)域滾動(dòng)
- 2022-12-10 Android入門之TextClock的使用教程_Android
- 2022-07-13 Android單選多選按鈕的使用方法_Android
- 2022-05-27 Flutter狀態(tài)管理Bloc之定時(shí)器示例_Android
- 2022-08-04 Unity中協(xié)程IEnumerator的使用方法介紹詳解_C#教程
- 2022-09-19 C語言中switch語句基本用法實(shí)例_C 語言
- 2022-06-06 詳細(xì)講解Docker虛擬化_docker
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲(chǔ)小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯(cuò)誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡(jiǎn)單動(dòng)態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對(duì)象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支