您好,登錄后才能下訂單哦!
第一篇文章中用c實現了靜態順序表,但是使用靜態順序表還有不足的地方。當我們需要存儲的數據很少時,如果靜態順序表的數組容量較大就會造成空間的浪費;當我們需要存儲的數據很多時,如果靜態順序表的數組容量較小可能就會造成數據丟失。所以一般情況我們應該盡量把順序表實現成動態的。需要多大容量就開辟多大容量。
靜態順序表和動態順序表只有以下函數不同:
1.定義結構體時,多定義一個capacity,并對capacity進行初始化和增加大小的設置;
#define INIT_CAPACITY 3 #define DEFAULT_INC 3
typedef struct { DataType *Data; int size; int capacity; }SeqList,*pSeqList;
2.動態順序表多了容量檢測函數(沒有容量時進行動態開辟);
void CheckCapacity(pSeqList pSeq) { assert(pSeq); //當存儲的有效值個數和容量相等時進行擴容 if(pSeq->size == pSeq->capacity) { pSeq->Data = (DataType*)realloc(pSeq->Data,pSeq->capacity + DEFAULT_INC); pSeq->capacity = pSeq->capacity + DEFAULT_INC; } }
3.動態順序表中進行數據存儲時先要進行容量檢測;
void PushBack(pSeqList pSeq, DataType x) { assert(pSeq); CheckCapacity(pSeq); pSeq->Data[pSeq->size++] = x; } void PushFront(pSeqList pSeq, DataType x) { int i = 0; assert(pSeq); CheckCapacity(pSeq); for(i = pSeq->size; i > 0; i--) { pSeq->Data[i] = pSeq->Data[i-1]; } pSeq->Data[0] = x; pSeq->size++; } void Insert(pSeqList pSeq,int pos,DataType x) { int i = 0; assert(pSeq); assert((pos<pSeq->size) && (pos >= 0)); CheckCapacity(pSeq); for(i = pSeq->size; i>pos; i--) { pSeq->Data[i] = pSeq->Data[i-1]; } pSeq->Data[pos] = x; pSeq->size++; }
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。