学习算法和数据结构的第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;
}
相关推荐
虾球xz1 小时前
游戏引擎学习第147天
数据库·学习·游戏引擎
*.✧屠苏隐遥(ノ◕ヮ◕)ノ*.✧2 小时前
C语言_数据结构总结8:链式队列
c语言·开发语言·数据结构·链表·visualstudio·visual studio
网络安全King2 小时前
学习网络安全需要哪些基础?
学习
dankokoko2 小时前
OPENGLPG第九版学习 -颜色、像素和片元 PART1
学习
真就死难3 小时前
完全日期(日期枚举问题)--- 数学性质题型
算法·日期枚举
项目題供诗3 小时前
ES语法学习
学习·elasticsearch·django
不知道取啥耶4 小时前
C++ 滑动窗口
数据结构·c++·算法·leetcode
花间流风4 小时前
晏殊几何学讲义
算法·矩阵·几何学·情感分析
@心都4 小时前
机器学习数学基础:42.AMOS 结构方程模型(SEM)分析的系统流程
人工智能·算法·机器学习
虾球xz4 小时前
游戏引擎学习第146天
学习·ffmpeg·游戏引擎