学习算法和数据结构的第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;
}
相关推荐
来自远方的老作者4 分钟前
第7章 运算符-7.2 赋值运算符
开发语言·数据结构·python·赋值运算符
wanderist.7 分钟前
算法模板-字符串
数据结构·算法·哈希算法
xiaoye-duck7 分钟前
《算法题讲解指南:动态规划算法--子序列问题》--29.最长递增子序列的个数,30.最长数对链,31.最长定差子序列
c++·算法·动态规划
風清掦11 分钟前
【江科大STM32学习笔记-10】I2C通信协议 - 10.1 软件I2C读写MPU6050
笔记·stm32·单片机·嵌入式硬件·物联网·学习
Yzzz-F11 分钟前
Problem - 2180D - Codeforces
算法
moonsea020312 分钟前
2023.9.25
算法
汀、人工智能15 分钟前
[特殊字符] Python基础语法速成教程
算法·链表·均值算法·哈希表·lru缓存·python基础语法速成教程
tankeven19 分钟前
HJ164 太阳系DISCO
c++·算法
来自远方的老作者22 分钟前
第7章 运算符-7.1 算术运算符
开发语言·数据结构·python·算法·算术运算符
Devlive 开源社区23 分钟前
DockMaster Pro v1.0.0 正式发布
学习