日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

顺序表及其基本应用

發(fā)布時間:2024/4/17 编程问答 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 顺序表及其基本应用 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

順序表及其基本應(yīng)用

順序表的優(yōu)點是可以更好的查找元素, 下面進行了初始化、增、刪、改、查、刪除等基本實現(xiàn)

  • 結(jié)構(gòu)體及其部分定義
#include <stdio.h> #define ERROR 0 #define OK 1 #define Overflow 2 //表示上溢 #define Underflow 3 //表示下溢 #define NotPresent 4 //表示元素不存在 #define Duplicate 5 //表示有重復(fù)元素typedef int Status; //結(jié)構(gòu)體 typedef struct seqList {int n; //長度int maxLength;int *element; //可以是自己想要的數(shù)據(jù)類型,這里我就用int了 }SeqList;
  • 順序表初始化
Status Init(SeqList *L, int mSize) {L->maxLength = mSize;L->n = 0;L->element = (int *)malloc(sizeof(int)*mSize); //動態(tài)生成一維空間if (!L->element)return ERROR;return OK; }
  • 順序表查找
Status Find(SeqList L, int i, int *x) {if (i < 0 || i >L.n - 1)return ERROR; //判斷是否越界*x = L.element[i]; //通過取出值,通過x傳遞回去return OK; }
  • 順序表的元素插入
Status Insert(SeqList *L, int i, int x) {int j;if (i < -1 || i > L->n - 1)return ERROR;if (L->n == L->maxLength)return ERROR;for (j = L->n - 1; j > i; j--)L->element[j + 1] = L->element[j];L->element[i + 1] = x;L->n = L->n + 1;return OK; }
  • 順序表元素刪除
Status Delete(SeqList *L, int i) {int j;if (i < 0 || i > L->n - 1)return ERROR;if (!L->n) //判斷是否為空return ERROR;for (j = i + 1; j < L->n; j++)L->element[j - 1] = L->element[j];L -> n--;return OK;} //輸出順序表 Status Output(SeqList *L) {int i;if (!L->n)return ERROR;for (i = 0; i < L->n; i++)printf("%d ", L->element[i]);printf("\n");return OK; }
  • 刪除順序表
void Destory(SeqList *L) {L->n = 0;L->maxLength = 0;free(L->element); }
  • 小小demo驗證一下
int main() {int i;SeqList list;Init(&list, 10);for (i = 0; i < 10; i++)Insert(&list, i - 1, i);Output(&list);Delete(&list, 0);Output(&list);Destory(&list);return 0; }

源代碼

#include <stdio.h> #define ERROR 0 #define OK 1 #define Overflow 2 //表示上溢 #define Underflow 3 //表示下溢 #define NotPresent 4 //表示元素不存在 #define Duplicate 5 //表示有重復(fù)元素typedef int Status; //結(jié)構(gòu)體 typedef struct seqList {int n; //長度int maxLength;int *element; //可以是自己想要的數(shù)據(jù)類型,這里我就用int}SeqList;//順序表初始化 Status Init(SeqList *L, int mSize) {L->maxLength = mSize;L->n = 0;L->element = (int *)malloc(sizeof(int)*mSize); //動態(tài)生成一維空間if (!L->element)return ERROR;return OK; }//順序表查找 Status Find(SeqList L, int i, int *x) {if (i < 0 || i >L.n - 1)return ERROR; //判斷是否越界*x = L.element[i]; //通過取出值,通過x傳遞回去return OK; }//順序表的元素插入 Status Insert(SeqList *L, int i, int x) {int j;if (i < -1 || i > L->n - 1)return ERROR;if (L->n == L->maxLength)return ERROR;for (j = L->n - 1; j > i; j--)L->element[j + 1] = L->element[j];L->element[i + 1] = x;L->n = L->n + 1;return OK; }//順序表元素刪除 Status Delete(SeqList *L, int i) {int j;if (i < 0 || i > L->n - 1)return ERROR;if (!L->n) //判斷是否為空return ERROR;for (j = i + 1; j < L->n; j++)L->element[j - 1] = L->element[j];L -> n--;return OK;} //輸出順序表 Status Output(SeqList *L) {int i;if (!L->n)return ERROR;for (i = 0; i < L->n; i++)printf("%d ", L->element[i]);printf("\n");return OK; }//刪除順序表 void Destory(SeqList *L) {L->n = 0;L->maxLength = 0;free(L->element); }int main() {int i;SeqList list;Init(&list, 10);for (i = 0; i < 10; i++)Insert(&list, i - 1, i);Output(&list);Delete(&list, 0);Output(&list);Destory(&list);return 0; }

總結(jié)

以上是生活随笔為你收集整理的顺序表及其基本应用的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。