線性表及其實現
typedef int Position;//為已定義好的資料型別建立別名為position;
typedef struct LNode *List;//建立型別為LNode的指標List
struct LNode {//建立資料結構;
ElementType Data[MAXSIZE];//(約定元素的資料型別為ElementType);
Position Last;
};
/* 初始化 */
List MakeEmpty()
{
List L;
L = (List)malloc(sizeof(struct LNode));//為結點L動態分配記憶體
L->Last = -1;//空間最後一個的值為-1;
return L;//返回長度l
}
/* 查詢 */
#define ERROR -1
Position Find( List L, ElementType X )
{
Position i = 0;//從0開始找;
while( i <= L->Last && L->Data[i]!= X )//兩個判斷條件,①找沒找完②找沒找到。
i++;
if ( i > L->Last ) return ERROR; /* 如果沒找到,返回錯誤資訊 */
else return i; /* 找到後返回的是儲存位置 */
}
/* 插入 */
/*注意:在插入位置引數P上與課程視訊有所不同,課程視訊中i是序列位序(從1開始),這裡P是儲存下標位置(從0開始),兩者差1*/
bool Insert( List L, ElementType X, Position P )
{ /* 在L的指定位置P前插入一個新元素X */
Position i;
if ( L->Last == MAXSIZE-1) {
/* 表空間已滿,不能插入 */
printf("表滿");
return false;
}
if ( P<0 || P>L->Last+1 ) { /* 檢查插入位置的合法性 */
printf("位置不合法");
return false;
}
for( i=L->Last; i>=P; i-- )
L->Data[i+1] = L->Data[i]; /* 將位置P及以後的元素順序向後移動 */
L->Data[P] = X; /* 新元素插入 */
L->Last++; /* Last仍指向最後元素 */
return true;
}
/* 刪除 */
/*注意:在刪除位置引數P上與課程視訊有所不同,課程視訊中i是序列位序(從1開始),這裡P是儲存下標位置(從0開始),兩者差1*/
bool Delete( List L, Position P )
{ /* 從L中刪除指定位置P的元素 */
Position i;
if( P<0 || P>L->Last ) { /* 檢查空表及刪除位置的合法性 */
printf("位置%d不存在元素", P );
return false;
}
for( i=P+1; i<=L->Last; i++ )
L->Data[i-1] = L->Data[i]; /* 將位置P+1及以後的元素順序向前移動 */
L->Last--; /* Last仍指向最後元素 */
return true;
}
相關文章
- 線性表及其演算法(java實現)演算法Java
- 線性表1.0(陣列實現)陣列
- 線性表-順序表C語言實現C語言
- 線性表的使用——順序實現
- go語言使用切片實現線性表Go
- 資料結構:線性表(Python實現基本操作)資料結構Python
- MySQL表連線及其優化MySql優化
- 線性表
- 資料結構和演算法(一)線性表實現資料結構演算法
- 線性表的順序儲存C++程式碼實現C++
- pytorch實現線性迴歸PyTorch
- TensorFlow實現線性迴歸
- 實驗二:順序表的基本操作實現及其應用
- 線性表 & 雜湊表
- 2.1線性表
- 線性表演算法實現演算法
- Chapter 1 線性表APT
- 實驗2.2 線性表的應用:遊戲遊戲
- 線性迴歸 go 語言實現Go
- Pytorch 實現簡單線性迴歸PyTorch
- AOP如何實現及其原理
- Set介面及其實現類
- 分散式鎖及其實現分散式
- 字首樹及其Java實現Java
- 實現elementUI表單的全域性驗證UI
- 線性表的基本操作
- 線性表——連結串列
- 線性表學習1
- 資料結構實驗三:線性表綜合實驗資料結構
- 【pytorch_5】線性迴歸的實現PyTorch
- 字典樹及其C++實現C++
- Bloom實現及其數學分析OOM
- Symbol 及其 屬性Symbol
- 什麼是實時渲染及其重要性
- 資料結構——線性表資料結構
- 資料結構 | 線性表資料結構
- 資料結構-線性表資料結構
- 資料結構—線性表資料結構