c實現的動態順序表

    第一篇文章中用c實現了靜態順序表,可是使用靜態順序表還有不足的地方。當咱們須要存儲的數據不多時,若是靜態順序表的數組容量較大就會形成空間的浪費;當咱們須要存儲的數據不少時,若是靜態順序表的數組容量較小可能就會形成數據丟失。因此通常狀況咱們應該儘可能把順序表實現成動態的。須要多大容量就開闢多大容量。數組

     靜態順序表和動態順序表只有如下函數不一樣:ide

     1.定義結構體時,多定義一個capacity,並對capacity進行初始化和增長大小的設置;函數

#define INIT_CAPACITY 3
#define DEFAULT_INC 3


typedef struct
{
	DataType *Data;
	int size;
	int capacity;
}SeqList,*pSeqList;


     2.動態順序表多了容量檢測函數(沒有容量時進行動態開闢);spa

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.動態順序表中進行數據存儲時先要進行容量檢測;ci

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++;
}
相關文章
相關標籤/搜索