【初阶数据结构之顺序表实现】(二)

简介: 【初阶数据结构之顺序表实现】(二)

image.gif

每一个不曾起舞的日子,都是对生命的辜负。


初阶数据结构之动态顺序表实现



三、实现具体功能代码页(SeqList.c)


#define _CRT_SECURE_NO_WARNINGS 1
#include"SeqList.h"
#include<assert.h>
void SeqListInit(SeqList* pq)//初始化
{
  assert(pq);//断言,判断是否可以执行1/0
  pq->a = NULL;
  pq->size = 0;
  pq->capacity = 0;
}
void SeqListDestory(SeqList* pq)
{
  assert(pq);
  free(pq->a);
  pq->a = NULL;
  pq->capacity = pq->size = 0;
}
void SeqCheckCapacity(SeqList* pq)
{
  if (pq->size == pq->capacity)//满了,需要增容
  {
    int newcapacity = pq->capacity == 0 ? 4 : pq->capacity * 2;
  //SeqDataType* newA = malloc(sizeof(SeqDataType) * newcapacity);
    SeqDataType* newA  =realloc(pq->a,sizeof(SeqDataType)* newcapacity);//或者直接扩容
    if (newA == NULL)
    {
      printf("realloc fail\n");
      exit(-1);
    }
    pq->a = newA;
    pq->capacity = newcapacity;
  }
}
void SeqListPushBack(SeqList* pq, SeqDataType x)
{
  assert(pq);
  SeqCheckCapacity(pq);
  pq->a[pq->size] = x;
  pq->size++;
}
void SeqListPrint(SeqList* pq)
{
  assert(pq);
  for (int i = 0; i < pq->size; ++i)
  {
    printf("%d ", pq->a[i]);
  }
  printf("\n");
}
void SeqListPushFront(SeqList* pq, SeqDataType x)
{
  assert(pq);
  SeqCheckCapacity(pq);
  int end = pq->size - 1;
  while (end >= 0)
  {
    pq->a[end + 1] = pq->a[end];  
    end--;
  }
  pq->a[0] = x;
  pq->size++;
}
void SeqListPopBack(SeqList* pq)
{
  assert(pq);
  assert(pq->size > 0);
  --pq->size;
}
void SeqListPopFront(SeqList* pq)
{
    assert(pq);
  for (int i = 0; i < pq->size - 1; i++)
  {
    pq->a[i] = pq->a[i + 1];
  }
  if(pq->size)
    pq->size--;
}


三(补).test.c主函数代码页


#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<stdlib.h>
#include"SeqList.h"
void TestSeqList1()
{
  SeqList s;
  SeqListInit(&s);//ʼ
  SeqListPushBack(&s, 1);
  SeqListPushBack(&s, 2);
  SeqListPushBack(&s, 3);
  SeqListPushBack(&s, 4);
  SeqListPushBack(&s, 5);
    SeqListPushFront(&s, 0);
    SeqListPushFront(&s, 0);
    SeqListPushFront(&s, 0);
    SeqListPushFront(&s, 0);
  SeqListPrint(&s);
  SeqListPopBack(&s);
  SeqListPrint(&s);
  SeqListPopBack(&s);
  SeqListPrint(&s);
  SeqListDestory(&s);//
}
int main()
{
  TestSeqList1();
  return 0;
}

微信图片_20230221132007.png


四.总结


当然,最详细的完整代码在这里:链接: 顺序表完整代码

相关文章
|
1月前
|
存储 编译器 C语言
数据结构-顺序表详解(看这篇就足够了,哈哈哈)
数据结构-顺序表详解(看这篇就足够了,哈哈哈)
52 2
|
24天前
|
存储 算法 安全
2024重生之回溯数据结构与算法系列学习之顺序表【无论是王道考研人还真爱粉都能包会的;不然别给我家鸽鸽丢脸好嘛?】
顺序表的定义和基本操作之插入;删除;按值查找;按位查找等具体详解步骤以及举例说明
|
24天前
|
存储 C语言
【数据结构】顺序表(c语言实现)(附源码)
本文介绍了线性表和顺序表的基本概念及其实现。线性表是一种有限序列,常见的线性表有顺序表、链表、栈、队列等。顺序表是一种基于连续内存地址存储数据的数据结构,其底层逻辑是数组。文章详细讲解了静态顺序表和动态顺序表的区别,并重点介绍了动态顺序表的实现,包括初始化、销毁、打印、增删查改等操作。最后,文章总结了顺序表的时间复杂度和局限性,并预告了后续关于链表的内容。
56 3
|
24天前
|
算法 安全 NoSQL
2024重生之回溯数据结构与算法系列学习之顺序表习题精讲【无论是王道考研人还真爱粉都能包会的;不然别给我家鸽鸽丢脸好嘛?】
顺序表的定义和基本操作之插入;删除;按值查找;按位查找习题精讲等具体详解步骤以及举例说明
|
1月前
|
存储 Java
数据结构第二篇【关于java线性表(顺序表)的基本操作】
数据结构第二篇【关于java线性表(顺序表)的基本操作】
31 6
|
1月前
|
存储 安全 Java
【用Java学习数据结构系列】探索顺序表和链表的无尽秘密(附带练习唔)pro
【用Java学习数据结构系列】探索顺序表和链表的无尽秘密(附带练习唔)pro
25 3
|
1月前
|
存储 C语言
探索C语言数据结构:利用顺序表完成通讯录的实现
本文介绍了如何使用C语言中的顺序表数据结构实现一个简单的通讯录,包括初始化、添加、删除、查找和保存联系人信息的操作,以及自定义结构体用于存储联系人详细信息。
21 2
|
1月前
|
存储
数据结构(顺序表)
数据结构(顺序表)
27 0
|
1月前
|
存储 算法
【数据结构】新篇章 -- 顺序表
【数据结构】新篇章 -- 顺序表
15 0
|
1月前
|
存储 测试技术
探索数据结构:顺序表的实现与应用
探索数据结构:顺序表的实现与应用