91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

c實現的動態順序表

發布時間:2020-07-09 00:35:25 來源:網絡 閱讀:252 作者:伊憶墨 欄目:編程語言

    第一篇文章中用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++;
}


向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

廉江市| 尖扎县| 呼伦贝尔市| 旺苍县| 安新县| 锦州市| 克拉玛依市| 德化县| 通化县| 会宁县| 梨树县| 汉中市| 德保县| 宁武县| 惠来县| 调兵山市| 富蕴县| 桐梓县| 泗水县| 通道| 霸州市| 分宜县| 衡阳县| 临夏市| 磐石市| 高阳县| 梅河口市| 济宁市| 洛隆县| 凤山市| 玉树县| 扶绥县| 崇左市| 安义县| 青田县| 庆云县| 化德县| 新营市| 凭祥市| 章丘市| 南宫市|