IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> 数据结构之顺性表 -> 正文阅读

[数据结构与算法]数据结构之顺性表

单链表

链表定义

typedef struct node
{
    int data;
    struct node * next;
}LinkNode,*LinkList;

初始化链表

带头结点

bool InitList(LinkList &L)
{
    L = (LinkNode*)malloc(sizeof(LinkNode));
    if(L == NULL)
        return false; //内存不足,分配失败
    L->next = NULL;
    return true;
}

不带头节点

bool InitList(LinkList &L)
{
    L=NULL;
    return true;
}

建立链表

头插法

带头结点

LinkList head_insert(LinkList &L)
{
    int x;
    L = (LinkNode*)malloc(sizeof(LinkNode));
    L->next = NULL;
    LinkNode *p;
    while(cin>>x)
    {
        p = (LinkNode*)malloc(sizeof(LinkNode));
        p->data = x;
        p->next = L->next;
        L->next = p;
    }
    return L;
}

尾插法

正向建立链表

带头节点

LinkList tail_insert(LinkList &L)
{
    int x;
    L = (LinkNode*)malloc(sizeof(LinkNode));
    LinkNode *p,*tail=L;
    while(cin>>x)
    {
        p = (LinkNode*)malloc(sizeof(LinkNode));
        p->data = x;
        tail->next = p;
        tail = p;
    }
    tail->next = NULL;
    return L;
}

插入操作

第i个位置插入

有头节点

bool insert(LinkList &L,int i,ElemType data)
{
    if(i < 1)//输入i值不合法
        return false;
    LinkNode *p = L;
    int j = 0;
    while(p != NULL&&j < i-1)//找到第i-1个节点
    {
        p=p->next;
        j++;
    }
    if(p == NULL)//输入i值不合法
        return false;
    LinkNode *e = (LinkNode*)malloc(sizeof(LinkNode));
    e->data = data;
    e->next = p->next;
    p->next = e;
}

最好时间复杂度O(1),向第一个位置插入节点

平均时间复杂度O(n),一共有n+1个位置,每个位置被插入的概率为\frac{1}{n+1},第一个位置到第n+1个位置的操作次数分别为,1,2,3...,n.平均操作次数为

\frac{1}{n+1}*(1+2+...+n)=\frac{1}{n+1}*\frac{(n+1)*n}{2}=\frac{n}{2}

最差时间复杂度O(n),向最后一个位置插入节点

无头节点

bool insert(LinkList &L,int i,ElemType data)
{
    if(i < 1)
        return false;
    if(i == 1)
    {
        LinkNode * s = (LinkNode*)malloc(sizeof(LinkNode));
        s->data = data;
        s->next = L;
        L = s;
        return true;
    }
    LinkNode *p = L;
    int j = 1;
    while(p != NULL && j < i-1)
    {
        p = p->next;
        j++;
    }
    if(p==NULL)
        return false;
    LinkNode *s = (LinkNode*)malloc(sizeof(LinkNode))
    s->data = data;
    s->next = p->next;
    p->next = s->next;
    return true;
}

复杂度与有头节点相同

※给定指针,在指针前插节点

带头结点

可以在给定指针后插入一个新节点,然后将新节点的值与当前指针指向节点的值互换,这样就起到了前插节点的作用。

bool InsertPriorNode(LinkNode *p,ElemType data)
{
    if(p == NULL)
        return false;
    LinkNode *s = (LinkNode*)malloc(sizeof(LinkNode));
    s->data = p->data;
    p->data = data;
    s->next = p->next;
    p->next = s;
    return true;
}

?最优、最差、平均时间复杂度均为O(1)

删除操作

删除链表中第i个位置的元素

带头节点

bool Delete(LinkList &L,int i,ElemType &e)
{
    if(i<1)
        return false;
    LinkNode *p = L;
    int j = 0;
    while(p != NULL && j < i-1)
    {
        p=p->next;
        j++;
    }
    if(p == NULL)
        return false;
    if(p->next == NULL)
        return false;
    LinkNode * s = p->next;
    p->next = s->next;
    e = s->data;
    free(s);
    return true;
}

最好时间复杂度为O(1)

最差时间复杂度为O(n)

平均时间复杂度为O(n):有n个节点,每个节点被删除的概率为\frac{1}{n},所以共需操作\frac{n+1}{2}

删除给定指针指向的节点

当要删除的是最后一个节点时,无法使用这种方法

bool DeleteNode(LinkNode *p)
{
    if(p==NULL)
        return false;
    LinkNode *s = p->next;
    p->data = s->data;
    p->next = s->next;
    free(s);
    return false;
}

时间复杂度为O(1)

查找操作

按位查找

LinkNode *GetElem(LinkList &L,int i)
{
    if(i<0)
        return false;
    LinkNode *p = L;
    int j = 0;
    while(p != NULL && j < i)
    {
        p=p->next;
        j++;
    }
    return p;
}

最优时间复杂度为O(1)

最差和平均时间复杂度为O(n)

按值查找

LinkNode *GetElem(LinkList &L,ElemType e)
{
    LinkNode *p = L;
    while(p != NULL && p->data != e)
    {
        p=p->next;
    }
    return p;
}

最优时间复杂度为O(1)

最差和平均时间复杂度为O(n)

双链表

双链表的定义

typedef struct node
{
    int data;
    struct node * next,*prior;
}DNode,*DLinkList;

双链表的初始化

bool InitDLinkList(DLinkList &L)
{
    L = (DNode*)malloc(sizeof(DNode));
    if(L==NULL)
        return false;
    L->next = NULL;
    L->prior = NULL;
    return true;
}

双链表的判空

bool isEmpty(DLinkList &L)
{
    if(L->next == NULL)
        return true;
    return false;
}

指定指针后插入节点

bool InsertNextDNode(DNode *p,DNode *s)
{
    if(p==NULL||s==NULL)
        return false;
    s->next = p->next;
    if(p->next != NULL)
    {
        p->next->prior = s;
    }
    s->prior = p;
    p->next = s;
    return true;
}

删除指定指针的后继节点

bool DeleteNextDNode(DNode *p)
{
    if(p==NULL)
        return false;
    if(p->next == NULL)
        return false;
    DNode *s = p->next;
    p->next = s->next;
    if(s->next != NULL)
        s->next->prior = p;
    free(s);
    return true;
}

循环单链表

定义与单链表一样,只是链表初始化时,头节点的指针指向头节点本身,此外,如果链表不空,那么链表中最后一个节点总是指向头节点。

初始化

bool InitLinkList(LinkList &L)
{
    L = (LNode*)malloc(sizeof(LNode));
    if(L==NULL)
        return false;
    L->next = L;
    return true;
}

很多时候,对链表的操作都是针对表头和表尾进行的,如果L指向头节点,那么操作表尾的时间复杂度为O(n).因为时循环单链表,所以可以让L指向尾节点。

循环双链表

初始化

bool InitLinkList(LinkList &L)
{
    L = (DNode*)malloc(sizeof(DNode));
    if(L==NULL)
        return false;
    L->next = L;
    L->next = L;
    return true;
}

静态链表

定义

typedef struct Node
{
    ElemType data;//存储数据元素
    int next;     //下一个元素的数组下标
}SLinkLIst[MaxSize];
  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2021-07-15 16:28:07  更:2021-07-15 16:30:07 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/28 12:08:11-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码