鏈表反轉的兩種方式

鏈表反轉的兩種方式

1.頭插法

先創建一個新的鏈表,然后不斷遍歷我們想要反轉的鏈表,再一個一個使用頭插法插入到我們新建立的鏈表中,這樣鏈表就倒置了。

LinkList Reverse(LinkList re)
{LinkList n;n = (LinkList)malloc(sizeof(LNode));n->next = NULL;while (re->next != NULL){LinkList cnt = (LinkList)malloc(sizeof(LNode));cnt->data = re->next->data;cnt->next = n->next;n->next = cnt;re = re->next;}return n;
}
2.列表原地倒置

主要就是創建兩個變量一個,next, 另一個 prev,從前往后過一遍即可。

LinkList Reverse(LinkList re)  
{  LinkList prev = NULL, curr = re, next;  while (curr != NULL)  {  next = curr->next;  curr->next = prev;  prev = curr;  curr = next;  }  return prev; // prev最終會是新的頭節點  
}

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

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

相關文章

C語言代碼風格

程序文件的說明,一般放在文件頭部注釋。 用來描述文件的作用、作者、日期等信息。一般格式如下: /** 文件名:filename.c* 功能:簡要描述文件的功能或作用* 作者:作者姓名* 日期:創建日期或最近修改日期*/…

Textual Learning2 -- 使用時的小問題

1、出現的問題: 在vscode里面直接運行函數會顯示報錯: 我嘗試在vscode中含textual庫的環境下運行,但仍然報錯 2、解決方案: 在命令行中運行: 首先按winR,輸入cmd打開命令行 或在已經安裝的conda環境&a…

古人的智慧結晶——水銃:揭秘明清時期的消防神器

明代的《奇器圖說》是一本記錄了當時各種奇巧機械的著作,而水銃則是書中記載的一項令人驚嘆的發明,它不僅展示了古人對物理原理的深刻理解,更是早期消防技術的一個縮影。 水銃,這個名字聽起來似乎有些陌生,但在古代&am…

在數據庫水平擴展中,名人問題(Celebrity Problem)也被稱為熱點鍵問題(Hotspot Key Problem)。

在數據庫水平擴展中,名人問題(Celebrity Problem)也被稱為熱點鍵問題(Hotspot Key Problem)。這是指某些特定的鍵(例如名人或非常受歡迎的內容)會導致某個分片(shard)被過…

電腦文件kernel32.dll缺失要怎么處理?怎么才能一鍵修復kernel32.dll文件

關鍵系統文件kernel32.dll的缺失,這種情況不僅會導致系統運行不穩定,甚至可能完全無法啟動某些應用程序。kernel32.dll 是一個至關重要的動態鏈接庫文件,它與Windows操作系統的多個基本操作相關聯,包括內存管理、進程和線程的控制…

dledger原理源碼分析系列(二)-心跳

簡介 dledger是openmessaging的一個組件, raft算法實現,用于分布式日志,本系列分析dledger如何實現raft概念,以及dledger在rocketmq的應用 本系列使用dledger v0.40 本文分析dledger的心跳 關鍵詞 Raft Openmessaging 心跳/…

C++中的常成員函數

2024年6月29日,周日下午 例如,以下是一個常成員函數的示例: class MyClass { public:int getValue() const {return value;} private:int value; };常成員函數是C中一種特殊的成員函數,它具有以下特點: 不可修改對象…

Flink Window DEMO 學習

該文檔演示了fink windows的操作DEMO 環境準備: kafka本地運行:kafka部署自動生成名字代碼:隨機名自動生成隨機IP代碼:隨機IPFlink 1.18 測試數據 自動向kafka推送數據 import cn.hutool.core.date.DateUtil; import com.alibab…

技術賦能教育:校園3D電子地圖與AR導航解決方案

隨著高考的落幕,又一批新鮮血液即將注入大學校園。面對陌生的環境,如何快速適應、準確找到目標地點,成為新生們的一大難題。同時,對于學校而言,如何向報考人員直觀展示校園環境,提供沉浸式參觀體驗&#xf…

Mybatis-Plus學習|快速入門CRUD、主鍵生成策略(雪花算法、主鍵自增等)、自動填充、樂觀鎖、分頁插件、邏輯刪除

MyBatisPlus概述 為什么要學習它呢?MyBatisPlus可以節省我們大量工作時間,所有的CRUD代碼它都可以自動化完成! JPA、tk-mapper、MyBatisPlus 偷懶的! MyBatis-Plus(簡稱 MP)是一個 MyBatis 的增強工具,在 MyBatis 的基礎上只做增強不做改變&#xff…

Pytorch學習之torch.nn.functional.pad()函數

PyTorch學習之torch.nn.functional.pad函數 一、簡介 torch.nn.functional.pad 是 PyTorch 中用于對張量進行填充操作的函數。填充操作在處理圖像、序列數據等任務時非常常見,它可以在張量的指定維度兩端添加一定數量的元素,填充方式多樣,包…

Git的基本使用方法

Git的基本使用方法 大家好,我是免費搭建查券返利機器人省錢賺傭金就用微賺淘客系統3.0的小編,也是冬天不穿秋褲,天冷也要風度的程序猿!今天我們將深入探討Git的基本使用方法,Git作為目前最流行的版本控制系統之一&…

Day 48 消息隊列集群RabbitMQ

消息隊列集群-RabbitMQ 一、消息中間件 中間件 tomcat java web中間件 web容器 mysql php php mysql uwsgi python mysql mycat 數據庫中間件 rabbitMQ 消息中間件 1、簡介 MQ 全稱為(Message Queue消息隊列)。是一種應用程序對應用程序的通信方…

【全球首個開源AI數字人】DUIX數字人-打造你的AI伴侶!

目錄 1. 引言1.1 數字人技術的發展背景1.2 DUIX數字人項目的開源意義1.3 DUIX數字人技術的獨特價值1.4 本文目的與結構 2. DUIX數字人概述2.1 定義與核心概念2.2 硅基智能與DUIX的關系2.3 技術架構2.4 開源優勢2.5 應用場景2.6 安全與合規性 3. DUIX數字人技術特點3.1 開源性與…

【Java Gui精美界面】IDEA安裝及配置SwingX

SwingX 是一個基于 Swing 的 Java GUI 庫,旨在為 Swing 提供額外的功能和豐富的組件 特點描述基于 Swing繼承了 Swing 的所有特性和功能。豐富組件SwingX 提供了一組高級 UI 組件,例如 TreeTable仍在發展中不活躍的發展ing。。。支持搜索高亮如 TreeTab…

【分布式系列】分布式鎖的設計與實現

💝💝💝歡迎來到我的博客,很高興能夠在這里和您見面!希望您在這里可以感受到一份輕松愉快的氛圍,不僅可以獲得有趣的內容和知識,也可以暢所欲言、分享您的想法和見解。 推薦:kwan 的首頁,持續學…

steam社區加載異常、加載失敗、無法加載、黑屏的解決方法

隨著steam夏季特賣的臨近,最近幾天開啟史低折扣的大作已經越來越少了,不過也并不是沒有。最經典的知名大作文明6之前已經打到1折的骨折價了,沒想到也能背刺,現在是新史低價0.5折11元,很多玩家入手后紛紛前往社區看新手…

ZABBIX-7.0LTS在線部署部署教程

ZABBIX-7.0LTS在線部署部署教程 環境: 操作系統: ubuntu 22.04zabbix-server版本: 7.0LTS系統配置[需結合監控的業務量提供配置]: 建議2C(CPU)8G(運行) 100GB(存儲)架構:LNMP 第一步: 系統初始化 1.配置…

計算機網絡知識整理筆記

目錄 1.對網絡協議的分層? 2.TCP/IP和UDP之間的區別? 3.建立TCP連接的三次握手? 4.斷開TCP連接的四次揮手? 5.TCP協議如何保證可靠性傳輸? 6.什么是TCP的擁塞控制? 7.什么是HTTP協議? 8…

MySQL InnoDB支持幾種行格式

數據庫表的行格式決定了一行數據是如何進行物理存儲的,進而影響查詢和DML操作的性能。 在InnoDB中,常見的行格式有4種: 1、COMPACT:是MySQL 5.0之前的默認格式,除了保存字段值外,還會利用空值列表保存null…