創建一個單鏈表,實現頭部插入和尾部插入

来源:http://www.cnblogs.com/ldhbetter/archive/2016/01/06/5105059.html
-Advertisement-
Play Games

/*目的:創建一個單鏈表,實現尾部插入,頭部插入,遍歷鏈表*/#include #include #include //定義一個結構體,用來表示一個節點,包含指針域,數據域struct node{ int data; //數據域 struct node *next; //指針域,...


/*
目的:創建一個單鏈表,實現尾部插入,頭部插入,遍歷鏈表
*/


#include <stdio.h>
#include <string.h>
#include <stdlib.h>

//定義一個結構體,用來表示一個節點,包含指針域,數據域

struct node
{
int data; //數據域

struct node *next; //指針域,指向節點的指針,用來連接兩個節點
};

//定義一個函數,用來創建節點,為節點分配堆記憶體,由於堆記憶體殘留有隨機值,創建成功後清空記憶體
//函數的返回值需要是struct node *類型,因為創建了一個節點,要操作這個節點,就需要得到這個節點的地址信息

struct node *create_node(int data) //int data :為節點的數據域傳值
{
struct node *p = (struct node *)malloc(sizeof(struct node)); // 創建一個節點,並返回其地址值保存到 p 中

if(NULL == p) //判斷節點是否成功創建
{
printf("malloc erro");
return NULL;
}

bzero(p,sizeof(struct node)); //調用#include <string.h>中的函數,功能是清理申請的臟記憶體

//節點創建成功並清理後,就填充節點
p -> data = data;
p -> next = NULL;

return p; //返回節點的地址值
}


//尾部插入函數的實現:通過頭指針找到最後一個節點,再將新節點與最後一個節點關聯,插入完成;
void insert_tail(struct node *pHeader,struct node *new)
{
//接收頭指針的值,開始遍歷鏈表,找到尾節點
struct node *p = pHeader;

while(NULL != p -> next) //遍歷鏈表,找到尾節點
{

p = p -> next;

}

//遍歷結束,找到最後一個節點就是p
//將新節點的地址值放入最後一個節點的指針域

p -> next = new; //尾部插入成功

new -> next = NULL;
}

 

//頭部插入函數的實現:先將第一個節點的地址值放入新節點的指針域,再將新節點的地址放入頭節點的指針域
void insert_head(struct node *hNode,struct node *new)
{
if(NULL == hNode -> next)
{
hNode -> next = new;
new -> next = NULL;
}
else
{
new -> next = hNode -> next;
hNode -> next = new;
}

}

 

 

 

 

 

int main(void)
{
struct node *pHeader = create_node(0);
insert_head(pHeader,create_node(1));
insert_head(pHeader,create_node(2));
insert_head(pHeader,create_node(3));
insert_head(pHeader,create_node(4));

printf("*********************************頭部插入********************************\n");
printf("node 1:%d.\n",pHeader -> next -> data);
printf("node 2:%d.\n",pHeader -> next ->next -> data);
printf("node 3:%d.\n",pHeader -> next -> next ->next ->data);
printf("node 4:%d.\n",pHeader -> next ->next ->next ->next -> data);


/***********************************************************************************************/

struct node *pH = create_node(0);
insert_tail(pH,create_node(1));
insert_tail(pH,create_node(2));
insert_tail(pH,create_node(3));
insert_tail(pH,create_node(4));

printf("*********************************尾部插入********************************\n");
printf("node 1:%d.\n",pH -> next -> data);
printf("node 2:%d.\n",pH -> next ->next -> data);
printf("node 3:%d.\n",pH -> next -> next ->next ->data);
printf("node 4:%d.\n",pH -> next ->next ->next ->next -> data);

return 0;
}


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • CSS實現的背景圖片替代顏色代碼:有時候在背景圖片由於網路或者其他原因沒有顯示的時候,可以使用指定的背景顏色替代,下麵就是一段能夠實現此功能的代碼:background: url("a.jpg") no-repeat #ccc;原文地址是:http://www.softwhy.com/forum.p...
  • jQuery列印json格式對象實例代碼:所謂的json格式對象其實就是對象直接量,很多教程多說這是json對象,其實這是不正確。下麵是一段列印json格式對象的實例代碼,希望能夠對初學者有所幫助。代碼如下: 螞蟻部落 原文地址是:http://www.softwhy.com/f...
  • 通過上下左右鍵控制div的運行方向:使用小鍵盤附近的上下左右鍵控制方向可能在很多應用程式中都有用到,有時候甚至特別的方便,比如有些游戲可以使用者四個鍵控制方位,下麵就簡單介紹一下javascript如何實現使用這四個鍵控制div的運動方向。方向鍵控制div的移動-螞蟻部落紅色方塊為鍵盤操作區域,您可...
  • 實現table細線表格效果代碼:細線表格相比較表格的預設表格來說要美觀很多,當然更受歡迎,下麵就通過代碼實例介紹一下如何實現此效果。代碼如下: 螞蟻部落 螞蟻部落一 螞蟻部落二 javascript教程 jQuery教程 ...
  • jQuery實現的垂直可伸縮導航菜單:垂直可伸縮導航菜單在網頁中非常的常用,首先可以進行分類,第二個也可以節省網頁的空間,本章節就通過實例代碼分享一個這樣的效果,希望能夠給需要者帶來一定的幫助。代碼實例如下:螞蟻部落 螞蟻部落一 前端教程 ...
  • javascript實現的iframe數據共用介面:在iframe與父視窗或者與子視窗傳遞數據是一個麻煩的事情,如果我們能夠寫一個一勞永逸的介面那就再方便不過了,下麵就來簡答介紹一下如何實現此功能。原理就是將數據緩存早window.top這個視窗,這樣無論子視窗父視窗的層次如何變化,數據總是存在不會...
  • 查看效果:http://hovertree.com/texiao/css/14/本效果用css3的animation實現動畫定義和用法animation 屬性是一個簡寫屬性,用於設置六個動畫屬性:animation-nameanimation-durationanimation-timing-fun...
  • Dubbo服務的運行方式 服務容器是一個standalone的啟動程式,因為後臺服務不需要Tomcat或JBoss等Web容器的功能,如果硬要用Web容器去載入服務提供方,增加複雜性,也浪費資源。 服務容器只是一個簡單的Main方法,並載入一個簡單的Spring容器,用於暴露服務。 服務容器的載入內...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...