【数据结构】线形顺序结构----顺序表(包含全部代码实现)

1、线形表

1.1 概念

线性表是n个具有相同特性的数据元素的有限序列。 常见的线性表包含顺序表、链表、栈、队列、字符串等。

线性表在逻辑上是线性结构,但物理结构上并不一定是连续的,线性表通常以数组和链式结构的形式存储。
 

2、顺序表

2.1 概念
  • 顺序表是用一段物理地址连续的存储单元依次存储数据元素的线性结构.
2.2 分类
  • 静态顺序表:使用定长数组存储
  • 动态顺序表:使用动态开辟的数组存储

 

3、顺序表实现

顺序表实现

3.1 静态顺序表
#pragma once 
#include <stdio.h>
// #include <vld.h>
#include <malloc.h>
#include <assert.h>

#define seqint int
#define SEQLIST_SIZE 8;


struct SeqList
{
  seqint *arr;
  size_t capacity;
  size_t size;
};

// 声明所有的函数
void SeqListInit(SeqList *plist);
void SeqlistDestory(SeqList *plist);
void SeqListPush_back(SeqList *plist, seqint x);
void SeqListPush_front(SeqList *plist, seqint x);
void show_list(SeqList *plist);

size_t SeqListLength(SeqList *plist);
void SeqListPop_back(SeqList *plist);
void SeqListClear(SeqList *plist);
bool SeqListInsertByPos(SeqList*plist, int pos, seqint x);
void SeqListSort(SeqList* plist);
size_t SeqListCapacity(SeqList *plist);

void SeqListPopFront(SeqList* plist);
bool SeqListInsertByVal(SeqList* plist, seqint x);
bool SeqListEraseByPos(SeqList* plist, int pos);
bool SeqListEraseVal(SeqList* plist, seqint x);
bool SeqListFind(SeqList* plist, seqint x);

// 
// 判断顺序表是否满
bool isFull(SeqList* plist)
{
  assert(plist != NULL);
  return plist->capacity == plist->size;
}

// 判断顺序表是否为空
bool isZero(SeqList* plist)
{
  assert(plist != NULL);
  return plist->size == 0;
}

///

// 初始化顺序表
void SeqListInit(SeqList *plist)
{
  plist->capacity = SEQLIST_SIZE;
  plist->size = 0;
  plist->arr =(seqint*)malloc(sizeof(seqint) * plist->capacity);
}

// 销毁顺序表
void SeqlistDestory(SeqList *plist)
{
  assert(plist != NULL);
  plist->capacity = 0;
  plist->size = 0;
  free(plist);
  plist = NULL;
}

// 顺序表尾插
void SeqListPush_back(SeqList *plist, seqint x)
{
  assert(plist != NULL);

  if(isFull(plist)){
    printf("顺序表已满,不能插入!!!\n");
  }
  plist->arr[plist->size] = x;
  plist->size++;
}

// 顺序表尾删
void SeqListPop_back(SeqList *plist)
{
  assert(plist);
  if(isZero(plist))
  {
    printf("顺序表为空,不能删除!!!\n");
    return;
  }
  plist->size--;
}

// 顺序表头插
void SeqListPush_front(SeqList *plist, seqint x)
{
  assert(plist != NULL);
  if(isFull(plist))
  {
    printf("顺序表已满,不能插入!!!\n");
    return;
  }
  for(int i = (int)plist->size - 1; i >= 0; --i)
  {
    plist->arr[i] = plist->arr[i+1];
  }
  plist->size++;
  plist->arr[0] = x;
}

// 顺序表头删
void SeqListPopFront(SeqList* plist)
{
  assert(plist);
  if(isZero(plist))
  {
    printf("顺序表为空,不能删除!!!\n");
    return;
  }
  for(int i = 1; i < (int)plist->size; ++i)
  {
    plist->arr[i] = plist->arr[i+1];
  }
  plist->size--;
}

// 打印顺序表
void show_list(SeqList *plist)
{
  assert(plist);
  for(int i = 0; i < (int)plist->size; ++i)
  {
    printf("%d ", plist->arr[i]);
  }
  printf("\n");
}

// 返回顺序表的有效元素的个数
size_t SeqListLength(SeqList *plist)
{
  assert(plist);
  return plist->size;
}

// 顺序表的容量
size_t SeqListCapacity(SeqList *plist)
{
  assert(plist);
  return plist->capacity;
}

// 查找数字
bool SeqListFind(SeqList* plist, seqint x)
{
  assert(plist);
  for(int i = 0; i < (int)plist->size; ++i)
  {
    if(x == plist->arr[i])
      return true;
  }
  return false;
}

// 顺序表排序
void SeqListSort(SeqList* plist)
{
  assert(plist);
  int endindex = 0;
  // 冒泡排序
  int sortborder = (int)plist->size - 1;
  for(int i = 0; i < (int)plist->size; ++i)
  {
    for(int j = 0; j < sortborder; ++j)
    {
      if(plist->arr[j] > plist->arr[j+1])
      {
        int temp = plist->arr[j];
        plist->arr[j] = plist->arr[j+1];
        plist->arr[j+1] = temp;
        endindex = j;
      }
    }
    sortborder = endindex;
  }
}

// 清空数组
void SeqListClear(SeqList *plist)
{
  assert(plist);
  plist->size = 0;
}

//

// 任意位置插入数字
bool SeqListInsertByPos(SeqList*plist, int pos, seqint x)
{
  assert(plist);
  if(isFull(plist))
  {
    printf("顺序表已满,无法插入!!!\n");
    return false;
  }
  for(int i = (int)plist->size - 1; i >= pos; --i)
  {
    plist->arr[i] = plist->arr[i+1];
  }
  plist->size++;
  plist->arr[pos] = x;
  return true;
}

// 插入值为x的数字(在排序之后)
bool SeqListInsertByVal(SeqList* plist, seqint x)
{
  assert(plist);
  if(isFull(plist))
  {
    printf("顺序表已满,无法插入!!!\n");
    return false;
  }
  int i = -1;
  for(int i = 0; i < (int)plist->size; ++i)
  {
    if(plist->arr[i] > x)
      break;
  }
  return SeqListInsertByPos(plist, i, x); 
}

// 删除任意位置的数字
bool SeqListEraseByPos(SeqList* plist, int pos)
{
  assert(plist);
  if(isZero(plist))
  {
    printf("顺序表为空,不能删除!!!\n");
    return false;
  }
  for(int i = pos; i < (int)plist->size; ++i)
  {
    plist->arr[i] = plist->arr[i+1];
  }

  plist->size--;
  return true;
}

// 删除任意值
bool SeqListEraseVal(SeqList* plist, seqint x)
{
  assert(plist);
  if(isZero(plist))
  {
    printf("顺序表为空,不能删除!!!\n");
    return false;
  }
  int i;
  for(i = 0; i < (int)plist->size; ++i)
  {
    if(plist->arr[i] == x)
      break;
  }

  if(SeqListEraseByPos(plist, i))
    return true;
  return false;
}
3.2 动态顺序表扩容
// 顺序表扩容                                                                                                                           
SeqList* check(SeqList* plist)                                                                                                          
{                                                                                                                                       
   if(plist->size < plist->capacity)                                                                                                     
      return plist;                                                                                                                       
   int size = plist->size;                                                                                                                      
   SeqList* temp = (SeqList*)malloc(sizeof(SeqList)* size * 2);                                                                                
   for(int i = 0; i < size; ++i)
   {                                                                                                                                                      
       temp->arr[i] = plist->arr[i];
   }
 
   // 更新容量
   temp->capacity = size * 2;
   SeqlistDestory(plist);                                                                                                            
   return temp;                                                                                                                       
}        
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值