学习算法和数据结构的第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;
}
相关推荐
石像鬼₧魂石2 小时前
内网渗透靶场实操清单(基于 Vulhub+Metasploitable 2)
linux·windows·学习·ubuntu
hh随便起个名3 小时前
力扣二叉树的三种遍历
javascript·数据结构·算法·leetcode
醇氧4 小时前
org.jetbrains.annotations的@Nullable 学习
java·开发语言·学习·intellij-idea
Dingdangcat864 小时前
城市交通多目标检测系统:YOLO11-MAN-FasterCGLU算法优化与实战应用_3
算法·目标检测·目标跟踪
敲敲了个代码4 小时前
隐式类型转换:哈基米 == 猫 ? true :false
开发语言·前端·javascript·学习·面试·web
xie_pin_an5 小时前
深入浅出 C 语言数据结构:从线性表到二叉树的实战指南
c语言·数据结构·图论
tang&5 小时前
滑动窗口:双指针的优雅舞步,征服连续区间问题的利器
数据结构·算法·哈希算法·滑动窗口
拼命鼠鼠5 小时前
【算法】矩阵链乘法的动态规划算法
算法·矩阵·动态规划
LYFlied5 小时前
【每日算法】LeetCode 17. 电话号码的字母组合
前端·算法·leetcode·面试·职场和发展
Pandora_4175 小时前
cursor学习
学习