学习算法和数据结构的第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;
}
相关推荐
玖剹10 分钟前
矩阵区域和 --- 前缀和
数据结构·c++·算法·leetcode·矩阵·动态规划·1024程序员节
zwz宝宝14 分钟前
第三次作业(密码学)
java·数据结构·算法
Nuyoah.44 分钟前
《Vue3学习手记7》
javascript·vue.js·学习
sxtyjty44 分钟前
tarjan缩点+强联通分量
算法
freyazzr44 分钟前
Leetcode刷题 | Day50_图论02_岛屿问题01_dfs两种方法+bfs一种方法
数据结构·c++·算法·leetcode·深度优先·图论·广度优先
悦悦子a啊1 小时前
C++之string
开发语言·数据结构·c++
我想进大厂1 小时前
图论---LCA(倍增法)
数据结构·c++·算法·图论
冰茶_1 小时前
WPF之Button控件详解
大数据·学习·microsoft·c#·wpf
明月看潮生1 小时前
青少年编程与数学 02-018 C++数据结构与算法 16课题、贪心算法
c++·算法·青少年编程·贪心算法·编程与数学
MrZWCui1 小时前
iOS—仿tableView自定义闹钟列表
学习·macos·ios·objective-c