赞
踩
目录
正文
顺序表和数组的区别?
先创建三个文件
如图:
在头文件(SeqList.h)中引入相应的头文件
在相应的源文件中引入头文件
第一步进行初始化和销毁代码的实现
在头文件中定义函数
在源文件中写函数方法
在测试文件中调用此方法,并调试
下面该插入数据
SeqList.h
在插入数据之前我们药判断顺序表中的空间是否充足 所以我们要写一个判断空间是否充足的函数
SeqList.h
SeqList.c
接下来是删除数据
SeqList.h
SeqList.c
接下来是在指定位置的插入数据/删除数据
先要找到指定位置才可之后的操作
SeqList.h
SeqList.c
附源码
SeqList.h
- #pragma once
- #include<stdio.h>
- #include<stdlib.h>
- #include<assert.h>
- //定义动态顺序表结构
- typedef int SLDataType;
- typedef struct SeqList
- {
- SLDataType* arr;
- int capacity;
- int size;
- }SL;
- //初始化
- void SLInit(SL* s);
- //销毁
- void SLDestroy(SL* s);
- //插入数据
- void SLPushBack(SL* s, SLDataType x);
- void SLPushFront(SL* s, SLDataType x);
- //打印顺序表
- void SLPrint(SL* s);
- //判断空间是否充足
- void SLCheckCapacity(SL* s);
- //删除
- void SLPopBack(SL* s);
- void SLPopFront(SL* s);
- //指定位置插入/删除数据
- void SLInsert(SL* s, SLDataType x, int pos);
- void SLErase(SL* s, int pos);
- //查找
- int SLFind(SL* s, int pos);
-
SeqList.c
- #define _CRT_SECURE_NO_WARNINGS 1
- #include"SeqList.h"
- //初始化
- void SLInit(SL* s) {
- s->arr = NULL;
- s->capacity = s->size = 0;
- }
- //销毁
- void SLDestroy(SL* s) {
- if (s->arr)//相当于s->arr != NULL
- {
- free(s->arr);
- }
- s->arr = NULL;
- s->capacity =s->size = 0;
- }
- //判断空间是否充足
- void SLCheckCapacity(SL* s)
- {
- //判断空间是否充足
- if (s->capacity == s->size)
- {
- int newCapacity = s->capacity == 0 ? 4 : 2 * s->capacity;
- SLDataType* tmp = (SLDataType*)realloc(s->arr, newCapacity * sizeof(SLDataType));
- if (tmp == NULL)
- {
- perror("realloc");
- exit(1);
- }
- s->arr = tmp;
- s->capacity = newCapacity;
- }
-
- }
- //插入数据
- //尾插
- void SLPushBack(SL* s, SLDataType x) {
- assert(s);//等价于s!=NULL
- SLCheckCapacity(s);
- //空间够的情况
- s->arr[s->size++] = x;
- }
- //头插
- void SLPushFront(SL* s, SLDataType x)
- {
- assert(s);
- SLCheckCapacity(s);
- for (int i = s->size; i > 0; i--)
- {
- s->arr[i] = s->arr[i - 1];
- }
- s->arr[0] = x;
- s->size++;
- }
- //打印顺序表
- void SLPrint(SL* s)
- {
- for (int i = 0; i < s->size; i++)
- {
- printf("%d ", s->arr[i]);
- }
- printf("\n");
- }
- //删除
- void SLPopBack(SL* s)
- {
- assert(s);
- assert(s->size);
- //s->arr[s->size - 1] = -1;
- s->size--;
- }
- void SLPopFront(SL* s)
- {
- assert(s);
- assert(s->size);
- for (int i = 0; i<s->size-1 ; i++)
- {
- s->arr[i] = s->arr[i + 1];
- }
- s->size--;
- }
-
- //指定位置插入/删除数据
- void SLInsert(SL* s, SLDataType x, int pos)
- {
- assert(s);
- assert(pos>=0 && pos<=s->size);
- SLCheckCapacity(s);
- for (int i = s->size; i >pos ; i--)
- {
- s->arr[i] = s->arr[i - 1];
- }
- s->arr[pos] = x;
- s->size++;
- }
- void SLErase(SL* s, int pos)
- {
- assert(s);
- assert(pos >= 0 && pos < s->size);
- for (int i = pos; i < s->size; i++)
- {
- s->arr[i] = s->arr[i + 1];
- }
- s->size--;
- }
- //查找
- int SLFind(SL* s, int pos)
- {
- assert(s);
- for (size_t i = 0; i < s->size; i++)
- {
- if (s->arr[i] == pos)
- return 1;
- }
- return -1;
- }
test.c
- #define _CRT_SECURE_NO_WARNINGS 1
- #include"SeqList.h"
- void test01()
- {
- SL s;
- SLInit(&s);
- //SLPushBack(&s, 1);
- //SLPushBack(&s, 2);
- //SLPushBack(&s, 3);
- //SLPushBack(&s, 4);
- //SLPushFront(&s, 1);
- //SLPushFront(&s, 2);
- //SLPushFront(&s, 3);
- //SLPushFront(&s, 4);
- //SLInsert(&s, 5, 2);
- //SLInsert(&s, 5, 0);
- //SLInsert(&s, 5, 6);
- //SLPopBack(&s);
- /*SLPopFront(&s);
- SLPrint(&s);
- SLPopFront(&s);
- SLPrint(&s);
- SLPopFront(&s);
- SLPrint(&s);
- SLPopFront(&s);
- SLPrint(&s);
- SLPrint(&s);*/
- SLDestroy(&s);
- };
- int main()
- {
- test01();
- return 0;
- }
以上就是顺序表的实现代码 如有问题欢迎留言!
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。