动态顺序表

###动态顺序表是由静态顺序表演变过来的,唯一的区别在于,动态顺序表可以分配空间,空间不够用时可以增容
这里写图片描述

##seqlist.h

#ifndef SEQLIST_H_
#define SEQLIST_H_
#include<stdio.h>
#include<malloc.h>


#define CAPACITY 3
typedef int DataType;
typedef struct Seqilst
{
	DataType* arr;
	int size;
	int capacity;
}Seqlist,*pSeqlist;

void InitSeqlist(pSeqlist sq);
void PushBack(pSeqlist sq,DataType data);
int CheckCapacity(pSeqlist sq);
void PopBack(pSeqlist);
void InsertPos(pSeqlist sq,DataType data,int pos);
void ErasePos(pSeqlist sq,int pos);
int IsEmpty(pSeqlist sq);
int Sepsize(pSeqlist sq);
int capacity(pSeqlist sq);
void destroy(pSeqlist sq);
void print(pSeqlist sq);
void test();


#endif




##seqlist.c

#include"seqlist.h"
#include<stdio.h>
#include<malloc.h>
#include<assert.h>

void InitSeqlist(pSeqlist sq)  //初始化
{
	assert(sq);
	sq->arr = (DataType *)malloc(CAPACITY*sizeof(DataType));
	if (sq->arr == NULL)
	{
		printf("capacity faild");
	}
	else
	{
		sq->size = 0;
		sq->capacity = CAPACITY;
	}
	
}
void PushBack(pSeqlist sq, DataType data)
{
	assert(sq);
	if (!CheckCapacity(sq))
	{
		//printf("不需要增容\n");
	}
	sq->arr[sq->size] = data;
	sq->size++;
	
}
int CheckCapacity(pSeqlist sq)
{
	assert(sq);
	if (sq->size >= sq->capacity)

	{
		int newcapacity = (DataType*)malloc(sizeof(DataType)*2 * sq->capacity);//很容易出错
		//若严谨考虑的话,此处应该在加sq->arr = ()realloc();
		sq->capacity = newcapacity;
	}
	else
		return 0;//不需要增容
	 
	return 1;


}
void PopBack(pSeqlist sq)
{
	assert(sq);
	if (sq->size==0)
		return;
	sq->size--;
}
void InsertPos(pSeqlist sq, DataType data, int pos)
{
	assert(sq);
	int end = pos-1;
	int i = sq->size-1;
	for (; i >= end; i--)
	{
		sq->arr[i+1] = sq->arr[i];
	}
	sq->arr[end] = data;
	sq->size++;
}
void ErasePos(pSeqlist sq, int pos)
{
	assert(sq);
	int i = pos - 1;
	for (i=pos-1; i < sq->size; i++)
	{
		sq->arr[i] = sq->arr[i + 1];
	}
	sq->size--;
}
int  IsEmpty(pSeqlist sq)
{
	return sq->size == 0;

}
int Sepsize(pSeqlist sq)
{
	return sq->size;
}
int capacity(pSeqlist sq)
{
	return sq->capacity;
}
void destroy(pSeqlist sq)
{
	free(sq->arr);
	sq->size = 0;
	sq->capacity = 0;
}
void print(pSeqlist sq)
{
	int i = 0;
	for (; i < sq->size; i++)
	{
		printf("%d ", sq->arr[i]);
	}
	printf("\n");
}



##test.c


void test()
{
	Seqlist sq;
	InitSeqlist(&sq);
	PushBack(&sq, 1);
	PushBack(&sq, 2);
	PushBack(&sq, 3);
	PushBack(&sq, 4);
	PushBack(&sq, 5);
	PushBack(&sq, 6);
	print(&sq);
	PopBack(&sq);
	print(&sq);
	InsertPos(&sq, 10, 4);
	print(&sq);
	ErasePos(&sq, 5);
	print(&sq);
}

int main()
{
test();
return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值