線性表及其實現
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(陣列實現)陣列
- 線性表分析及Java實現Java
- 線性表-順序表C語言實現C語言
- 線性表的使用——順序實現
- go語言使用切片實現線性表Go
- 資料結構:線性表(Python實現基本操作)資料結構Python
- 資料結構:線性表的順序實現2.2資料結構
- 資料結構中的線性表程式碼實現資料結構
- 線性結構-線性表
- 線性表
- 最小二乘法擬合非線性函式及其Matlab/Excel 實現函式MatlabExcel
- MySQL表連線及其優化MySql優化
- 資料結構和演算法(一)線性表實現資料結構演算法
- 線性表的順序儲存C++程式碼實現C++
- TensorFlow實現線性迴歸
- 【機器學習】線性迴歸sklearn實現機器學習
- 線性表演算法實現演算法
- pytorch實現線性迴歸PyTorch
- 實驗二:順序表的基本操作實現及其應用
- 實驗2.2 線性表的應用:遊戲遊戲
- Chapter 1 線性表APT
- HTTP/2特性及其在實際應用中的表現HTTP
- 線性迴歸 go 語言實現Go
- 【機器學習】線性迴歸python實現機器學習Python
- Android輕量的線性和百分比圖表實現Android
- 資料結構實驗三:線性表綜合實驗資料結構
- 線性表的基本操作
- 線性表學習(4)
- 對線性表的操作
- 線性表學習1
- Pytorch 實現簡單線性迴歸PyTorch
- 機器學習--線性迴歸--梯度下降的實現機器學習梯度
- 利用TensorFlow實現多元線性迴歸
- 利用TensorFlow實現線性迴歸模型模型
- 字首樹及其Java實現Java
- AOP如何實現及其原理
- Set介面及其實現類