leetcode-代碼隨想錄-鏈表-翻轉鏈表

題目

鏈接:206. 反轉鏈表 - 力扣(LeetCode)
給你單鏈表的頭節點 head ,請你反轉鏈表,并返回反轉后的鏈表。
image

輸入:head = [1,2,3,4,5]
輸出:[5,4,3,2,1]
class Solution {
public:ListNode* reverseList(ListNode* head) {}
};
思路 & 代碼
雙指針法
  1. 雙指針:①cur指針指向頭節點;②pre指針初始化為 NULL。
  2. 反轉:
    • 先保存 cur->next:temp = cur->next;
    • 反轉:pre = cur->next;
    • 移動:先移動pre, pre = cur;再移動cur, cur = temp;
  3. 結束條件:cur == NULL
  4. 返回鏈表:return pre;
    image.png
    image.png
    image.png
class Solution {
public:ListNode* reverseList(ListNode* head) {ListNode* cur = head;ListNode* pre = nullptr;while(cur){ListNode* temp = cur->next;cur->next = pre;pre = cur;cur = temp;}return pre;}
};
遞歸法

遞歸三部曲:

  1. 確定遞歸函數的參數和返回值
    • 參數:需要在遞歸中進行處理的
    • 返回值:根據返回值來確定返回類型
  2. 確定終止條件
  3. 確定單層遞歸邏輯
    • 確定每一層遞歸需要處理的信息。就是重復調用自己的過程。

image.png

class Solution {
public:ListNode* reversed(ListNode* cur, ListNode* pre){if(cur == nullptr) return pre;ListNode* temp = cur->next;cur->next = pre;return reversed(temp,cur);}ListNode* reverseList(ListNode* head) {return reversed(head, nullptr);}
};

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/76657.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/76657.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/76657.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

spring boot 集成redis 中RedisTemplate 、SessionCallback和RedisCallback使用對比詳解,最后表格總結

對比詳解 1. RedisTemplate 功能:Spring Data Redis的核心模板類,提供對Redis的通用操作(如字符串、哈希、列表、集合等)。使用場景:常規的Redis增刪改查操作。特點: 支持序列化配置(如String…

Linux紅帽:RHCSA認證知識講解(九)標準輸入輸出、重定向、過濾器與管道

Linux紅帽:RHCSA認證知識講解(九)標準輸入輸出、重定向、過濾器與管道 前言一、標準輸入與輸出、重定向,使用過濾器篩選文件信息1.1 Linux 的標準輸入與輸出1.2 什么是輸入重定向1.3 輸出重定向1.4 標準錯誤輸出重定向1.5 使用過濾…

搭建完全分布式系統時,為何必須同步服務器時間?

在構建完全分布式系統時,時間同步是保障系統一致性和可靠性的基石。本文將從完全分布式系統的核心特點、時間同步的必要性、不同步可能引發的災難性后果、主流時間同步協議對比及最佳實踐方案五個角度展開分析,幫助開發者深入理解時間同步的關鍵作用。 一…

MonkeyDev 如何創建一個root級級別的app,并執行root命令獲取iphone設備序列號serialNumber(ios15.8)

前提條件:有越獄的手機,XCode中已經安裝了Monkeydev 1. 和普通應用一個創建一個ios的工程 2. 在App的TARGETS>build setting> 中設置Apple Development 3. 設置User-Defined的配置 CODE_SIGNING_ALLOWED = NO MonkeyDevBuildPackageOnAnyBuild = NO MonkeyDevClearUi…

每日一題(小白)模擬娛樂篇13

今天題目比較簡單,直接分析。小藍想知道2024這個數字中有幾個1,計算機組成學習好的同學肯定可以直接長除法或者瞪眼法得出答案: 202411111101000(B)也就是說2024中有一共有六個1 接下來用代碼實現 ,我們也…

【藍橋杯】算法筆記2

這篇文章主要記錄動態規劃方面的學習。 動態規劃的核心思想: 把大問題分解成小問題,記住小問題的解,避免重復計算。 動態規劃(DP)的三大特點: ①最優子結構:大問題的最優解可以由小問題的最優解推導出來 ②重疊子問題:在求解過程中會反復遇到相同的小問題 ③無后效…

MINIQMT學習課程Day9

獲取qmt賬號的持倉情況后,我們進入下一步,如何獲得當前賬號的委托狀況 還是之前的步驟,打開qmt,選擇獨立交易, 之后使用pycharm,編寫py文件 導入包: from xtquant import xtdata from xtqua…

雜篇-行業分類一二-2(通、專用設備制造,汽車制造)

接上篇, 本篇列舉制造業中另外幾個細分行業:通用設備制造,專用設備制造,汽車制造業。 一、通用設備制造 分類 序號 類別名稱 說明 1 鍋爐及原動設備制造 1 鍋爐及輔助設備制造 指各種蒸汽鍋爐、汽化鍋爐,以及…

DHCP協議和win server2022無腦配置DHCP

DHCP(動態主機配置協議)用于分配IP地址的過程。這個過程也被稱為DORA,它是四個步驟首字母的縮寫。讓我們詳細看看每個步驟: 客戶機請求IP(Discover):當一個設備(客戶機)連接到網絡并需要獲取網絡配置(如IP地址、子網掩碼、默認網關等)時,它會發送一個DHCP Discover…

Visio | 將(.vsdx)導出為更清楚/高質量的圖片(.png) | 在Word里面的visio圖

此時大家在用Visio畫完圖直接復制到word里面后,如果后期需要重新保存高清圖片,但是此時圖片在word,是不是很多人會選擇直接crtlA截圖復制,這樣出來的圖又不清晰又小,完全不符合你導的審美,接下來跟著我&…

LLM面試題六

NLP方向CRF算法面試題 什么是CRF?CRF的主要思想是什么? 設X與Y是隨機變量,P(Y | X)是給定條件X的條件下Y的條件概率分布,若隨機變量Y構成一個由無向圖G(V,E)表示的馬爾科夫隨機場。則稱條件概率分布P(X | Y)為條件隨機場。CRF的主要思想統計…

每日一題(小白)ASCLL娛樂篇5

本題我們使用ASCLL值的方法解決,也可以打表去判斷。加深對ASCLL表的認識! 圖源ASCII 表 | 菜鳥教程,有需要的小伙伴可以在菜鳥詳細了解。 由題知要識別三種類型的字符,使用三個變量存儲最終值輸出即可。根據ASCLL表可知數字、大寫…

ffmpeg中格式轉換需要注意點總結

某些封裝格式(例如MP4/FLV/MKV等)的H.264碼流的SPS和PPS信息存儲在AVCodeccontext結構體的extradata中。分離某些封裝格式(例如MP4/FLV/MKV等)中的H.264的時候,需要首先寫入SPS和PPS,否則會導致分離出來的數據沒有SPS、PPS而無法播。需要使用ffmpeg中名稱…

小型語言模型與檢索增強生成系統的融合:機遇與挑戰

小型語言模型(SLMs)是大型語言模型(LLMs)的緊湊版本。其參數量通常比大型模型少得多:約30億或更少。這使得它們具有相對輕量級的特點,推理速度更快。 當前研究的一個有趣方向是將SLMs整合到檢索增強生成(RAG)系統中以提升性能。本文探討這一最新趨勢&…

使用 .NET 9 和 Azure 構建云原生應用程序:有什么新功能?

隨著 .NET 9 推出一系列以云為中心的增強功能,開發人員擁有比以往更多的工具來在 Azure 上創建可擴展、高性能的云原生應用程序。讓我們深入了解 .NET 9 中的一些出色功能,這些功能使構建、部署和優化云應用程序變得更加容易,并附有示例以幫助…

PostgreSQL:表分區與繼承

🧑 博主簡介:CSDN博客專家,歷代文學網(PC端可以訪問:https://literature.sinhy.com/#/?__c1000,移動端可微信小程序搜索“歷代文學”)總架構師,15年工作經驗,精通Java編…

Linux / Windows 下 Mamba / Vim / Vmamba 安裝教程及安裝包索引

目錄 背景0. 前期環境查詢/需求分析1. Linux 平臺1.1 Mamba1.2 Vim1.3 Vmamba 2. Windows 平臺2.1 Mamba2.1.1 Mamba 12.1.2 Mamba 2- 治標不治本- 終極版- 高算力版 2.2 Vim- 治標不治本- 終極版- 高算力版 2.3 Vmamba- 治標不治本- 終極版- 高算力版 3. Linux / Windows 雙平…

開源項目更新到個人倉庫二次開發并保持同步

當你克隆了一個開源項目并將其推送到自己的倉庫后,定期更新該開源項目并與你的本地修改同步是一個常見的需求。為了高效地管理這一過程,你可以使用 Git 的 upstream 遠程倉庫和 rebase 技術來保持代碼的整潔和線性歷史。 1. 設置上游遠程倉庫 首先&…

多輸入多輸出 | Matlab實現BO-GRU貝葉斯優化門控循環單元多輸入多輸出預測

多輸入多輸出 | Matlab實現BO-GRU貝葉斯優化門控循環單元多輸入多輸出預測 目錄 多輸入多輸出 | Matlab實現BO-GRU貝葉斯優化門控循環單元多輸入多輸出預測預測效果基本介紹程序設計參考資料 預測效果 基本介紹 Matlab實現BO-GRU貝葉斯優化門控循環單元多輸入多輸出預測&#…

MCP(模型上下文協議)入門指南:用Web開發的視角理解下一代AI引擎

引言:當Java Web遇到長期記憶 想象你正在開發一個在線法律咨詢平臺。用戶上傳一份300頁的合同后,連續提出了10個問題: 第3頁的違約條款具體內容是什么?請對比第15頁和第120頁的支付條件整份合同中最高的賠償金額是多少&#xff…