学习算法和数据结构的第15天

单链表的实现

顺序表的缺陷

​ 1、空间不够需要扩容,扩容存在消耗

2、头部或中间的位置插入删除,需要挪动,挪动数据也存在消耗;

3、避免频繁的进行扩容,一次扩容一般都是按数倍去扩(2倍),可能存在一定的空间浪费。

优点:

​ 支持随机访问

(有些算法,需要结构支持随机访问,比如:二分查找、优先的快排等)

链表

优点:

1、按需申请空间,不用了就释放空间(更合理的利用空间)

2、头部插入删除数据,不需要挪动数据,不存在空间浪费;

缺点:

​ 每一个数据,都需要存一个指针去链接后面数据节点(用下标直接访问第i个),不支持随机访问

尾插、头插

c 复制代码
#include<stdio.h>
#include"sList.h"
SLTNode*BuyListNode(SLTDateType x)
{
    SLTNode*newnode=(SLTdate*)malloc(sizeof(SLTNode));
    newnode->date=x;
    newnode->next=NULL;
    return 0;
}
void SListPrint(SLTNode*phead)
{
    SLTNode*cur=phead;
    while(cur!=NULL)
    {
        printf("%d->",cur->date);
        cur=cur->next;
    }
    printf("NULL\n");
}
//尾插
void SListPushBak(SLTNode**pphead,SLTDateTpye x)
    SLTNode*newode=(SLTNode*)malloc(sizeof(SLTNode));
newode->data=x;
newode->next=NULL;
if(*pphead==NULL)
{
    *pphead=newnode;
}
else
{
    //找到结尾点
    SLTNode*tail=*pphead;
    while(tail->next!=NULL)
    {
        tail=tail->next;
    }
    tail->next=nowode;
}
void SListPushFront(SLTNode**pphead,SLTDateTpye x)
{
    SLTNode*newnode=BuyListNode(x);
    newnode->next=*pphead;
    *phead=newnode;
}
//头插
void TestSList2()
{
    SLTNode*plist = NULL;
SListPushBack(&plist,1);
SListPushBack(&plist, 2);
SListPushBack(&plist,3);
SListPushBack(&plist,4);
    
SListPrint(plist);
    
SListPushFront(&plist, 1);
SListPushFront(&plist,2);
SListPushFront(&plist,3);
SListPushFront(&plist,4);
    
SListPrint(plist);
}
int main()
{
    TestSList2();
    return 0;
}
相关推荐
V搜xhliang024616 小时前
OpenClaw科研全场景用法:从文献到实验室的完整自动化方案
运维·开发语言·人工智能·python·算法·microsoft·自动化
汉克老师17 小时前
GESP2025年3月认证C++五级( 第三部分编程题(2、原根判断))
c++·算法·模运算·gesp5级·gesp五级·原根·分解质因数
Amazing_Cacao17 小时前
CFCA精品可可产区认证课程风土解析(美洲):打破风味堆叠的假象,建立时间轴上的层次展开阅读系统
学习
永远不会的CC17 小时前
浙江华昱欣实习(4月23日~ 4月19日)
后端·学习
数据皮皮侠17 小时前
上市公司创新韧性数据(2000-2024)|顶刊同款 EIR 指数
大数据·人工智能·算法·智慧城市·制造
爱上好庆祝17 小时前
学习js的第五天
前端·css·学习·html·css3·js
WL_Aurora17 小时前
Python 算法基础篇之链表
python·算法·链表
科研前沿17 小时前
纯视觉无感解算 + 动态数字孪生:室内外无感定位技术全新升级
大数据·人工智能·算法·重构·空间计算
qiaozhangchi17 小时前
求解器学习笔记
笔记·python·学习
代码中介商18 小时前
数据结构开篇:从问题到解决方案
数据结构