数据结构(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;
}
相关推荐
8Qi89 小时前
LeetCode 75:颜色分类(荷兰国旗问题)—— Java 题解 ✅
java·算法·leetcode·指针·排序
888CC++10 小时前
如何在 C 语言中进行程序调试?
前端·javascript·算法
pluviophile_s12 小时前
数据结构:第2讲:线性表
数据结构·笔记
(●—●)橘子……12 小时前
力扣第503场周赛练习理解
python·学习·算法·leetcode·职场和发展·周赛
明志数科14 小时前
4D时序标注技术详解:让机器人理解连续动作的数据基础
java·算法·机器人
KaMeidebaby14 小时前
卡梅德生物技术快报|原核表达系统工艺优化:包涵体重折叠 + 分子筛纯化实现功能 RBD 高效制备,附全参数配置
前端·人工智能·算法·数据挖掘·数据分析
无限码力14 小时前
携程0510笔试真题【单数组交换】
算法·携程笔试·携程笔试真题·携程0510笔试真题
Love_云宝儿15 小时前
WKT数据示例并与GeoJSON数据对比
数据结构·gis
BlockWay15 小时前
WEEX Labs 周度观察:微软-OpenAI 合作调整与AI 多云趋势
大数据·人工智能·算法·安全·microsoft