結構體學習

来源:https://www.cnblogs.com/wh217/p/18147842
-Advertisement-
Play Games

/******************************************************************************************************** * * 提高可移植性 Copyright (c) 2023-2024 cececlmx@ ...


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

  • 提高可移植性
  • Copyright (c) 2023-2024 [email protected] All right Reserved
  • ******************************************************************************************************/

include <stdio.h>

include <stdbool.h>

//指的是順序表中的元素的數據類型,用戶可以根據需要進行修改
typedef int DataType_t;

//構造記錄順序表SequenceList各項參數(順序表的首地址 + 順序表的容量 + 順序表中最後有效元素的下標)的結構體
typedef struct SequenceList
{
DataType_t * Addr; //記錄順序表首地址
unsigned int Size; //記錄順序表的容量
int Last; //順序表中最後元素的下標

}SeqList_t;

//創建順序表並對順序表進行初始化
SeqList_t * SeqList_Create(unsigned int size)
{
//1.利用calloc為順序表的管理結構體申請一塊堆記憶體
SeqList_t *Manager = (SeqList_t *)calloc(1,sizeof(Manager));

if(NULL == Manager)
{
	perror("calloc memory for manager is failed");
	exit(-1); //程式異常終止
}

//2.利用calloc為所有元素申請堆記憶體
Manager->Addr = (DataType_t *)calloc(size,sizeof(DataType_t));

if (NULL == Manager->Addr)
{
	perror("calloc memory for element is failed");
	free(Manager);
	exit(-1); //程式異常終止
}

//3.對管理順序表的結構體進行初始化(元素容量 + 最後元素下標)
Manager->Size = size;	//對順序表中的容量進行初始化
Manager->Last = -1;		//由於順序表為空,則最後元素下標初值為-1

return Manager;

}

//判斷順序表是否已滿
bool SeqList_IsFull(SeqList_t *Manager)
{
return (Manager->Last + 1 == Manager->Size) ? true : false;
}

//向順序表的尾部加入元素
bool SeqList_TailAdd(SeqList_t *Manager, DataType_t Data)
{
//1.判斷順序表是否已滿
if ( SeqList_IsFull(Manager) )
{
printf("SequenceList is Full!\n");
return false;
}

//2.如果順序表有空閑空間,則把新元素添加到順序表尾部
Manager->Addr[++Manager->Last] = Data;

return true;

}

//向順序表的頭部加入元素
bool SeqList_HeadAdd(SeqList_t *Manager, DataType_t Data)
{
//1.判斷順序表是否已滿
if ( SeqList_IsFull(Manager) )
{
printf("SequenceList is Full!\n");
return false;
}

//2.如果順序表有空閑空間,則需要把順序表所有元素向後移動1個單位
for (int i = Manager->Last;i >= 0;i--)
{
	Manager->Addr[i+1] = Manager->Addr[i];
}

//3把新元素添加到順序表的頭部,並且更新管理結構體中的元素下標+1
Manager->Addr[0] = Data;
Manager->Last++;

return true;

}

//判斷順序表是否已滿
bool SeqList_IsEmpty(SeqList_t *Manager)
{
return (-1 == Manager->Last) ? true : false;
}

//刪除順序表的元素
bool SeqList_Del(SeqList_t *Manager,DataType_t DestVal)
{
//1.判斷順序表是否為空
if ( SeqList_IsEmpty(Manager) )
{
printf("SequenceList is Empty!\n");
return false;
}

//2.此時需要查找目標值是否在順序表中
if (存在目標值)
{
	//剛好在尾部
	//剛好在頭部
	//剛好在中間
}
else
{
	return false;
}

}

//遍歷順序表的元素
SeqList_Print(SeqList_t *Manager)

int main(int argc, char const *argv[])
{

//1.創建順序表
SeqList_t * Manager = SeqList_Create(10);





return 0;

}


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

-Advertisement-
Play Games
更多相關文章
  • 題目:對順序表中的元素進行增加和刪除以及訪問 使用數組實現線性表的特性,需要知道三個條件:數組元素的容量、數組有效的最後一個元素的下標 /************************************************************************* * file ...
  • 順序表 題目一: 題目分析: 該題目需要先對順序表進行遍歷至元素x正確插入位置,再對順序表完成插入操作。因此涉及到for迴圈與if語句的使用 代碼實現 /******************************************************************** * * ...
  • 1:在離線的環境中導入鏡像 在無法訪問外網的情況下,通過將docker鏡像導出為一個包,然後導入到另外的一臺電腦上面,從而實現了不用訪問外網就能拉取鏡像了 #將鏡像輸出到這個tar包 [root@cleint ~]# docker save -o centos.tar centos #通過第三方的 ...
  • 2.1.1 命令提示符 在CentOS 7操作系統中,Linux命令提示符就像是你與電腦交流的一個小標誌,告訴你系統已經準備好接受你的指令了。 它通常會顯示在你打開的終端視窗或控制台的最前面。 讓我們來看一個示例: [root@node01 ~]$ 在這個示例中: root:是當前登錄的用戶名。 @ ...
  • 大家好,我是痞子衡,是正經搞技術的痞子。今天痞子衡給大家分享的是在i.MXRT1xxx系列上用NAND型啟動設備時可用兩級設計縮短啟動時間。 去年痞子衡寫過一篇騷操作文章 《藉助i.MXRT10xx系列INIT_VTOR功能可以縮短程式熱重啟時間》,這對於 NAND 型啟動設備上程式熱重啟時間的縮短 ...
  • 聲明: 以下內容為個人筆記,內容不完全正確,請謹慎參考。 正則表達式 含義: 正則表達式使用的每個單獨字元串來描述、匹配一些列符合語法規則的字元串。在很多文本編輯器里,正則表達式通常被用來檢索、替換那些符合某個模式的文本。在Linux中,grep,sed,awk等文本處理工具都支持正則表達式進行模式 ...
  • 在上一篇中,老周用 .NET Nano Framework 給大伙伴們演示了 WS2812 燈帶的控制,包括用 SPI 和 紅外RMT 的方式。利用 RMT 是一個很機靈的方案,不過,可能很多大伙伴對 ESP32 的 RMT 不是很熟悉。除了樂鑫自己的文檔,沒幾個人寫過相關的水文,可見這裡頭空白的水 ...
  • 聲明: 以下為個人筆記,內容不完全正確,請謹慎參考。 while迴圈 while迴圈結構 while [條件判斷] do 程式 done 腳本示例: 點擊查看代碼 #!/bin/bash while [ $a -le $1] do sum=$[ $sum + $a ] done echo $sum ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...