2.3 線性表的鏈式表示

来源:https://www.cnblogs.com/zhangsai/archive/2023/10/20/17777887.html
-Advertisement-
Play Games

知識總覽 2.3.1 單鏈表的定義 知識總覽 單鏈表定義 #include<stdio.h> #include<string.h> #include<stdlib.h> struct LNode{ int data; struct LNode *next; }; int main(){ struct ...


知識總覽

2.3.1 單鏈表的定義

知識總覽

單鏈表定義
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
struct LNode{
	int data;
	struct LNode *next;
};
int main(){	
	struct LNode *p=(struct LNode*)malloc(sizeof(struct LNode));
    return 0;
}
typedef重命名

typedef struct LNode{
  int data;
  struct LNode *next;
}LNode,*LinkList;

等同於

struct LNode{
    int data;
    struct LNode *next;
};
typedef struct LNode LNode;
typedef struct LNode *LinkList;

 

頭插法建立單鏈表

頭插法
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
typedef struct LNode{
  int data;
  struct LNode *next;
}LNode,*LinkList;
LinkList List_HeadInsert(LinkList &L){
	LNode *s;
	int x;
	L=(LinkList)malloc(sizeof(LNode));  //創建頭節點 
	L->next=NULL;                  //初始為空鏈表 
	scanf("%d",&x);                   //輸入節點的值 
	while(x!=9999){                   //輸出9999表示結束 
		s=(LNode*)malloc(sizeof(LNode));  //創建新節點 
		s->data=x;
		s->next=L->next;
		L->next=s;                  //將新節點插入表中,L為頭指針 
		scanf("%d",&x);
	}
	return L;
}
int main(){
	LinkList L;
	List_HeadInsert(L);
}

強調這是一個單鏈表      ————使用LinkList

強調這是一個節點         ————使用LNode*

 

不帶頭節點的單鏈表
#include<stdio.h>
#include<string.h>
#include<stdlib.h>

typedef struct LNode{
  int data;
  struct LNode *next;
}LNode,*LinkList;
//初始化一個空的單鏈表 
bool InitList(LinkList &L){
	L=NULL;    //空表,//防止臟數據 
	return true;
} 
//判斷單鏈表是否為空 
bool Empty(LinkList L){
	return (L==NULL);
} 
int main(){
	LinkList L; //聲明一個指向單鏈表的指針 //此處並沒有創建一個節點 
	InitList(L);
	Empty(L); 
}
帶頭結點的單鏈表
#include<stdio.h>
#include<string.h>
#include<stdlib.h>

typedef struct LNode{
  int data;
  struct LNode *next;
}LNode,*LinkList;
//初始化一個單鏈表 (帶頭結點)
bool InitList(LinkList &L){
    L=(LNode*)malloc(sizeof(LNode));
	if(L==NULL)
	    return false;
    L->next=NULL; 
	return true;
} 
//判斷單鏈表是否為空 (帶頭結點)
bool Empty(LinkList L){
    if(L->next==NULL)
	   return  true;
	else
	   return false;
} 
int main(){
	LinkList L; //聲明一個指向單鏈表的指針 
	InitList(L);
	Empty(L); 
}
  總結       2.3.2.1 知識總覽        
按位序插入(帶頭結點)
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
typedef struct LNode{
  int data;
  struct LNode *next;
}LNode,*LinkList;
//初始化一個單鏈表 (帶頭結點)
bool InitList(LinkList &L){
    L=(LNode*)malloc(sizeof(LNode));
	if(L==NULL)
	    return false;
    L->next=NULL; 
	return true;
} 
//判斷單鏈表是否為空 (帶頭結點)
bool Empty(LinkList L){
    if(L->next==NULL)
	   return  true;
	else
	   return false;
} 
//在第i個位置插入元素e(帶頭結點) 
bool ListInsert(LinkList &L,int i,int e){
	if(i<1)
	    return false;
	LNode *p;  //指針p指向當前掃描到的結點
	int j=0;   //當前p指向的是第幾個結點
	p=L;     //L指向頭結點,頭結點是第0個結點(不存數據)
	while(p!=NULL&&j<i-1){ //迴圈找到第i-1 個結點 //找位置 
		p=p->next;
		j++;
	}
	if(p==NULL)   //i值不合法 
	   return false;
	LNode *s=(LNode*)malloc(sizeof(LNode));
	s->data=e;
	s->next=p->next;
	p->next=s;   //將結點s連到p之後 
	return true; //插入成功 
}
int main(){
	LinkList L; //聲明一個指向單鏈表的指針 
	InitList(L);
	Empty(L); 
	ListInsert(L,1,9);
}
               

不帶頭節點

 

 

LNode * GetElem(LinkList L ,int i){
  int j=1;
  LNode *p=L->next;
  if(i==0)
    return L;
  if(i<1)
   return NULL;
  while(p!=NULL&&j<i){
   p=p->next;
   j++;
}

本文來自博客園,作者:abandon11,轉載請註明原文鏈接:https://www.cnblogs.com/zhangsai/p/17777887.html


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

-Advertisement-
Play Games
更多相關文章
  • 怎麼才能很好地避免低級故障?以下規範在大型互聯網公司經過了充分驗證,尤其適用於併發量大、數據量大的業務場景。 在設計資料庫技術方案時,我們是有自己的設計理念或者原則,還是更多依據直覺去設計?是否曾經懊悔線上發生過的一次低級故障?是否思考過怎樣才能避免?設計規範的價值在於提供了一份工作檢查清單,我們不 ...
  • 當用戶輸入網頁路徑,瀏覽器首先通過網路請求拿到html字元串,然後經過HTML解析、樣式計算、佈局、分層、繪製、分塊、光柵化、畫等過程,將頁面的內容最終呈現到了屏幕上。 ...
  • 這裡給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 最近遇到一個問題,計算滾動距離,滾動比例達到某界定值時,顯示mask,很常見吧^ _ ^ 這裡講的不是這個需求的實現,是其中遇到了一個比較有意思的bug,靠這個bug才達到了正確效果,以及這個bug是如何暴露的(很重要)。 下麵是演示代碼 ...
  • React採用on+事件名的方式來綁定一個事件,註意,這裡和原生的事件是有區別的,原生的事件全是小寫 onclick , React里的事件是駝峰 onClick ,React的事件並不是原生事件,而是合成事件。 事件回調的幾種寫法 1.直接在組件內定義一個非箭頭函數的方法,然後在render里直接 ...
  • 本文分享自華為雲社區《從0到1實現 OpenTiny 組件庫跨框架技術》,作者:華為雲社區精選 。 在華為雲《DTSE Tech Talk》技術直播第44期《0基礎玩轉 OpenTiny 跨框架組件庫,實現一站式前端進階》中,華為雲前端開發 DTSE 技術佈道師莫春輝老師在本期直播中與開發者一起交流 ...
  • 接上一節:從零用VitePress搭建博客教程(3) - VitePress頁腳、標題logo、最後更新時間等相關細節配置 六、首頁樣式修改 有時候覺得自帶的樣式不好看,想自定義,首先我們在docs/.vitePress新建一個theme文件夾,用來存放自定義佈局和主題修改的相關文件,如下所示 th ...
  • 目錄 1. HTTP協議 2. HttpServlet 內容 HTTP 什麼是HTTP協議 HTTP 協議一般指 HTTP(超文本傳輸協議)。超文本傳輸協議(英語:HyperText Transfer Protocol,縮寫:HTTP)是一種用於分散式、協作式和超媒體信息系統的應用層協議,是網際網路上 ...
  • Python支持來自數學的通常邏輯條件: 等於:a == b 不等於:a != b 小於:a < b 小於或等於:a <= b 大於:a > b 大於或等於:a >= b 這些條件可以以多種方式使用,最常見的是在"if語句"和迴圈中使用。 if語句是使用if關鍵字編寫的。 示例,if語句: a = ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...