数据结构(2)线性表

线性表顺序存储

线性表的静态分配

cs 复制代码
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
typedef int data_t;
#define N 100
typedef struct 
{
    data_t data[N];/* data */
    int length;
}sqlist,*sqlink;
sqlink list_creat()
{
    sqlink L;
    L=(sqlink)malloc(sizeof(sqlist));
    if(L==NULL)
    {printf("list malloc failed");
    return L;}

    memset(L,0,sizeof(sqlist));
    L->length=0;
    return L;

}
int list_clear(sqlink L)
{
    if(L=NULL)
    return -1;
    memset(L,0,sizeof(sqlist));
    L->length=0;
    return 0;
}
int list_insert(sqlink L, data_t value, int pos) {
    int i;

    //full
    if (L->length == N) {
        printf("list is full\n");
        return -1;
    }

    //check para   0<=pos<=Last+1  [0, last+1]
    if (pos < 0 || pos > L->length) {
        printf("Pos is invalid\n");
        return -1;
    }

    //move
    for (i = L->length-1; i >= pos; i--) {
        L->data[i+1] = L->data[i];
    }

    //update value 
    L->data[pos] = value;
    L->length++;
}
int main()
{
    sqlink L;
    L=list_creat();


}

特点:分配内存固定,容易存在溢出或内存浪费问题

动态分配

cs 复制代码
#include <stdio.h>
#include <stdlib.h>

// 动态分配顺序表结构定义
#define InitSize 10  // 初始长度

typedef int ElemType;
typedef struct 
{
     ElemType *data;  /* data */
    int length;
    int Maxsize;
}sqlist,*sqlink;

void Initlist(sqlink L)
{
    L->data=(ElemType*)malloc(sizeof(sqlist));
    L->length=0;
    L->Maxsize=InitSize;

}
void IncreaseSize(sqlink L,int len)
{
    ElemType *p=L->data;
    L->data=(ElemType)malloc((L->Maxsize+len)  *sizeof(ElemType));
    for(int i=0;i<L->length;i++){
        L->data[i]=p[i];

    }
    L->Maxsize=L->Maxsize+len;
    free(p);
}

特点:数据的存储地址在结构体外面,通过结构体成员指针指向数据存放内存的初始地址,可随时申请更大的内存空间来存放数据

线性表的顺序存储缺点

线性表的顺序存储结构有存储密度高及能够随机存取等优点,但存在以下不足:

(1)要求系统提供一片较大的连续存储空间。

(2)插入、删除等运算耗时,且存在元素在存储器中成片移动的现象

线性表链式存储

cs 复制代码
#include <stdio.h>
#include <stdlib.h>
typedef int data_t;
typedef struct node
{
    data_t data;
    struct node* next;
    
}LNode,* Linklist;

void InitList(Linklist L){
    L=(Linklist*)malloc(sizeof(LNode));
    L->next=NULL;
}
相关推荐
智者知已应修善业4 分钟前
【51单片机89C51及74LS273、74LS244组成】2022-5-28
c++·经验分享·笔记·算法·51单片机
洛水水26 分钟前
【力扣100题】33.验证二叉搜索树
算法·leetcode·职场和发展
SimpleLearingAI38 分钟前
聚类算法详解
算法·数据挖掘·聚类
刀法如飞1 小时前
Go 字符串查找的 20 种实现方式,用不同思路解决问题
算法·面试·程序员
Dlrb12113 小时前
C语言-指针数组与数组指针
c语言·数据结构·算法·指针·数组指针·指针数组·二级指针
WL_Aurora3 小时前
Python 算法基础篇之集合
python·算法
平行侠3 小时前
A15 工业路由器IP前缀高速检索与内存压缩系统
网络·tcp/ip·算法
阿旭超级学得完5 小时前
C++11包装器(function和bind)
java·开发语言·c++·算法·哈希算法·散列表
li星野5 小时前
位运算 & 数学 & 高频进阶九题通关(Python + C++)
c++·python·学习·算法
jerryinwuhan5 小时前
hello算法,简单讲(1)
算法·排序算法