C語言單鏈表的算法之逆序

一:什么是鏈表的逆序

? ? ? ? (1)鏈表的逆序又叫反向,意思就是把鏈表中所有的有效節點在鏈表中的順序給反過來

二:單鏈表逆序算法分析

? ? ? ? (1)當需要對一個數據結構進行操作時,就有必要有一套算法。這就是數據結構和算法的關系

? ? ? ? (2)算法的兩個層次:第一個層次是數學和邏輯上的算法;第二個層次是編程語言來實現算法

? ? ? ? (3)從邏輯上來講,鏈表的逆序有很多種方法。這些方法最終都能實現需要,但是效率是一樣的。彼此的可擴展性容錯性等不同

? ? ? ? (4)思路:首先先遍歷節點,然后將原鏈表中的頭指針頭節點作為新鏈表的頭指針頭節點,再將原鏈表中的有效節點挨個依次取出來,采用頭部插入的方法插入進新鏈表

? ? ? ? (5)鏈表逆序 = 遍歷 + 頭插入

三:逆序代碼實現

? ? ? ?(1)實現函數


/****************************************
函數名:reverse
作用:將鏈表進行反向排序
返回值:無
參數:ph 鏈表頭指針
****************************************/
void reverse(struct node *ph)
{strucct node *p = ph->pNEXT;STRUCT NODE *pback = ph;if((p == NULL) || (p->pNEXT == NULL))     //判斷是否是只有一個節點還是沒有有效節點{return;            //當鏈表中只有一個節點或沒有有效節點時不需要操作}//當鏈表有兩個或兩個以上的節點才需要進行操作while(NULL != p->pNEXT)    //判斷是不是最后一個節點{back = p->pNEXT;     //保存p節點后的一個節點if(p == ph->pNEXT){//原鏈表的第一個有效節點,在逆序之后會變成尾節點,將這個節點的//指針指向NULLp->pNEXT = NULL;}else{//不是原鏈表的第一個有效節點,指向上一個頭節點指向的節點地址p->pNEXT = ph->pNEXT;   }ph->pNEXT = p;    //頭節點指向新插入的節點p = pback;        //將下一個要插入的節點的地址給指針臨時變量}//在進行遍歷時判斷條件是不是最后一個節點,這樣會丟失最后一個節點insert_head(ph,p->pNEXT);}

(2)程序源碼

#include <stdio.h>
#include <string.h>
#include <stdlib.h>struct node
{int datas;struct node *pNEXT;};struct node *create(int a)
{struct node *p = (struct node *)malloc(sizeof(struct node));if(NULL == p){printf("malloc error!\n");return NULL;}memset(p,0,sizeof(struct node));  //bzero(p,sizeof(struct node));p->datas = a;p->pNEXT = NULL;return p;}void insert_tail(struct node *phead,struct node *new)
{struct node *p = phead;int cat = 0;while(NULL !=  p->pNEXT){p = p->pNEXT;cat++;}p->pNEXT = new;phead->datas = cat +1;}void insert_head(struct node *head,struct node *new)
{new->pNEXT =  head->pNEXT;head->pNEXT = new;head->datas += 1;}void ergodic(struct node *ph)
{struct node *p = ph;int cat = 0;printf("datas number is a: %d\n",p->datas);while(NULL !=  p->pNEXT){cat++;printf("datas number is :%d\n",cat);  p = p->pNEXT;  printf("datas is: %d\n",p->datas);    }}int delete(struct node *ph,int data)
{struct node *p = ph;struct node *prev = NULL;int cat = 0;while(NULL !=  p->pNEXT){prev = p;p = p->pNEXT; if(p->datas == data){if(NULL == p->pNEXT){       prev->pNEXT  = NULL;free(p);cat = ph->datas;ph->datas = cat -1;}else{prev->pNEXT  = p->pNEXT;free(p);cat = ph->datas;ph->datas = cat -1;}   return 0;}    }return -1;}void reverse(struct node *ph)
{strucct node *p = ph->pNEXT;STRUCT NODE *pback = ph;if((p == NULL) || (p->pNEXT == NULL))     //判斷是否是只有一個節點還是沒有有效節點{return;            //當鏈表中只有一個節點或沒有有效節點時不需要操作}//當鏈表有兩個或兩個以上的節點才需要進行操作while(NULL != p->pNEXT)    //判斷是不是最后一個節點{back = p->pNEXT;     //保存p節點后的一個節點if(p == ph->pNEXT){//原鏈表的第一個有效節點,在逆序之后會變成尾節點,將這個節點的//指針指向NULLp->pNEXT = NULL;}else{//不是原鏈表的第一個有效節點,指向上一個頭節點指向的節點地址p->pNEXT = ph->pNEXT;   }ph->pNEXT = p;    //頭節點指向新插入的節點p = pback;        //將下一個要插入的節點的地址給指針臨時變量}//在進行遍歷時判斷條件是不是最后一個節點,這樣會丟失最后一個節點insert_head(ph,p);}int main(void)
{struct node *phead = create(0);insert_tail(phead,create(12));   insert_tail(phead,create(13));insert_tail(phead,create(14));ergodic(phead);     //遍歷打印各個節點數據區reverse(phead);   //將鏈表進行逆序ergodic(phead);    //再次遍歷打印各個節點數據區return 0;}

運行結果:

?

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

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

相關文章

JS烏龜吃雞游戲

代碼&#xff1a; <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>烏龜游戲</title><script type"text/javascript">function move(obj){//烏龜圖片高度var wuGui_height 67;…

Conda跨平臺環境遷移

問題描述&#xff1a; 在一臺Ubuntu電腦上完全復刻在Windows中通過conda創建的環境。 導出環境 在Windows機器上&#xff0c;需要導出當前conda環境的配置。這將生成一個environment.yml文件&#xff0c;其中包含所有已安裝的包和版本信息。 打開Anaconda Prompt&#xff08;…

第一天:SLAM整體算法框架簡介

從零開始搭建一套SLAM系統 第一天:整體算法框架簡介以及學習建議 SLAM是什么 SLAM 和 SFM 是什么關系 不同點: SFM (Structure From Motion),稱之為傳統三維重建,這是一門計算機視覺學科的分支,特點是把圖片數據集集回來,離線慢慢精細化處理。常見應用就是重建某建筑物…

Django 模版繼承

1&#xff0c;設計母版頁 Test/templates/6/base.html <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><!-- 修正了模板標簽的全角字符問題 -->{% block title %}<title>這個是母版頁</title>{…

算法:鏈表

目錄 鏈表的技巧和操作總結 常用技巧&#xff1a; 鏈表中的常用操作 題目一&#xff1a;反轉一個單鏈表 題目二&#xff1a;鏈表的中間結點 題目三&#xff1a;返回倒數第k個結點 題目四&#xff1a;合并兩個有序鏈表 題目五&#xff1a;移除鏈表元素 題目六&#xff…

Linux下命令行重定向運算符的使用辦法

在Linux下&#xff0c;> 和 >> 是兩種常用的輸出重定向運算符&#xff0c;它們分別代表了覆蓋寫入和追加寫入的文件操作。這些運算符在命令行交互、腳本編程以及日常的系統管理中極為重要&#xff0c;能夠有效地控制程序或命令的輸出流向&#xff0c;提高工作效率。 …

平衡二叉搜索樹/AVL樹

VAL樹的特性 左右子樹高度差的絕對值不超過1。&#xff08;即左右子樹高度差取值為-1&#xff0c;0&#xff0c;1&#xff09;且左右子樹均為VAL樹右子樹的值大于左子樹的值 在搜索二叉樹中我們提及了搜索二叉樹的退化問題。 當有序&#xff08;升序或降序&#xff09;地插入…

摸魚大數據——Spark基礎——Spark環境安裝——Spark Local[*]搭建

一、虛擬機配置 查看每一臺的虛擬機的IP地址和網關地址 查看路徑: cat /etc/sysconfig/network-scripts/ifcfg-ens33 2.修改 VMware的網絡地址: 使用VMnet8 3.修改windows的對應VMware的網卡地址 4.通過finalshell 或者其他的shell連接工具即可連接使用即可, 連接后, 測試一…

如何在Java中實現事件驅動編程?

如何在Java中實現事件驅動編程&#xff1f; 大家好&#xff0c;我是免費搭建查券返利機器人省錢賺傭金就用微賺淘客系統3.0的小編&#xff0c;也是冬天不穿秋褲&#xff0c;天冷也要風度的程序猿&#xff01;今天我們將探討如何在Java中實現事件驅動編程&#xff0c;這是一種強…

AD PCB板子裁剪與淚滴設置

在剪裁板子時。首先&#xff0c;選擇選擇板子的機械層&#xff0c;之后選擇畫線。在原來的板子上畫上自己想要裁剪的圖形。如下下圖 之后&#xff0c;選擇按照所畫的線裁剪板子即可&#xff0c;如下 在焊接PCB時&#xff0c;為了防止多次焊接導至焊盤脫落可以加大焊點的接觸面積…

ESP32-C3模組上跑通MQTT(6)—— tcp例程(1)

接前一篇文章:ESP32-C3模組上跑通MQTT(5) 《ESP32-C3 物聯網工程開發實戰》 一分鐘了解MQTT協議 ESP32 MQTT API指南-CSDN博客 ESP-IDF MQTT 示例入門_mqtt outbox-CSDN博客 ESP32用自簽CA進行MQTT的TLS雙向認證通信_esp32 mqtt ssl-CSDN博客 特此致謝! 本回開始正式講…

mac docker 運行mysql5.7 鏡像失敗解決

12312 qemu: uncaught target signal 11 (Segmentation fault) InnoDB: Linux Native AIO interface is not supported on this platform. Please check your OS documentation and install appropriate binary of InnoDB. 問題如上 一般來說&#xff0c;拉取mysql8是沒問題…

淺談css的cusor屬性

在網頁設計中&#xff0c;細節決定成敗。CSS的cursor屬性是這些細節中的關鍵一環&#xff0c;它不僅影響著網頁的美觀&#xff0c;更關乎用戶體驗。今天&#xff0c;我們就來深入了解一下cursor屬性&#xff0c;看看如何通過它來增強網頁的交互性。 cursor屬性概覽 cursor屬性…

華潤萬家超市卡怎么用?

華潤的禮品卡不僅能線下門店使用&#xff0c;還能直接叫送貨上門 我最近用積分兌了幾張華潤卡&#xff0c;但是又沒有購物需求&#xff0c;送朋友吧面值又不大&#xff0c;朋友也說用不上 最后朋友建議我在收卡云上把卡出掉&#xff0c;我試了下92折出掉了&#xff0c;價格還…

代碼隨想錄算法訓練營第四十七天| 188.買賣股票的最佳時機IV ,309.最佳買賣股票時機含冷凍期 ,714.買賣股票的最佳時機含手續費

188. 買賣股票的最佳時機 IV - 力扣&#xff08;LeetCode&#xff09; class Solution {public int maxProfit(int k, int[] prices) {int[][] dp new int[prices.length][2*k];for(int i0;i<2*k;i){if(i%2 0){dp[0][i] -prices[0];}else{dp[0][i] 0;} }for(int i1;i…

綜合項目實戰--jenkins節點模式

一、DevOps流程 DevOps是一種方法論,是一系列可以幫助開發者和運維人員在實現各自目標的前提下,向自己的客戶或用戶交付最大化價值及最高質量成果的基本原則和實踐,能讓開發、測試、運維效率協同工作的方法。 DevOps流程(自動化測試部分) DevOps完整流程 二、gitee+j…

內網和外網的區別及應用

內網和外網的區別及應用 大家好&#xff0c;我是免費搭建查券返利機器人省錢賺傭金就用微賺淘客系統3.0的小編&#xff0c;也是冬天不穿秋褲&#xff0c;天冷也要風度的程序猿&#xff01;今天我們來探討一下計算機網絡中的內網和外網&#xff0c;它們的區別以及在實際應用中的…

go sync包(四) 讀寫鎖(二)

讀寫鎖 RWMutex 寫鎖 加鎖 RWMetex 的寫鎖復用了 Mutex&#xff1a; // Lock locks rw for writing. // If the lock is already locked for reading or writing, // Lock blocks until the lock is available. func (rw *RWMutex) Lock() {if race.Enabled {_ rw.w.state…

安全與發展并重:實施等保,促進企業可持續增長的邏輯

在數字經濟時代&#xff0c;信息安全不僅是企業穩健運營的基石&#xff0c;也是推動可持續發展的重要保障。網絡安全等級保護&#xff08;簡稱“等保”&#xff09;體系&#xff0c;作為國家層面設立的信息安全保障框架&#xff0c;其核心在于平衡安全與發展的關系&#xff0c;…

Java中如何進行分布式系統設計?

Java中如何進行分布式系統設計&#xff1f; 大家好&#xff0c;我是免費搭建查券返利機器人省錢賺傭金就用微賺淘客系統3.0的小編&#xff0c;也是冬天不穿秋褲&#xff0c;天冷也要風度的程序猿&#xff01;今天&#xff0c;我們來討論如何在Java中進行分布式系統設計。分布式…