当前位置: 首页 > news >正文

深圳品牌网站建设运维工程师的前景如何

深圳品牌网站建设,运维工程师的前景如何,网站建设与管理办法,电商网站的建设与维护我们这里接着上一篇单链表继续往下深入学习循环链表、双向链表。 链表 🎈3.循环链表🔭3.1循环链表的概念🔭3.2循环链表的基本操作🔎3.2.1创建空表🔎3.2.2插入操作🔎3.2.3删除操作 🎈4.双向链表&…

我们这里接着上一篇单链表继续往下深入学习循环链表、双向链表

链表

  • 🎈3.循环链表
    • 🔭3.1循环链表的概念
    • 🔭3.2循环链表的基本操作
      • 🔎3.2.1创建空表
      • 🔎3.2.2插入操作
      • 🔎3.2.3删除操作
  • 🎈4.双向链表
    • 🔭4.1类型定义
    • 🔭4.2头插法创建双向链表
    • 🔭4.3尾插法创建双向链表
    • 🔭4.4插入操作
    • 🔭4.5删除操作

🎈3.循环链表

🔭3.1循环链表的概念

循环链表是一种头尾相接的链表。它的特点是由链表的尾结点的指针域不为空,而是指向头结点,整个链表形成一个环。由此,从表中任何一个结点出发均可找到链表的其他结点。在单链表中,将终端结点的指针域NULL改为指向表头结点的或开始结点,就得到了单链形式的循环链表,并简称为单循环链表。与单链表一样,为了使空表和非空表处理一致,循环链表也可以设置一个头结点。空循环链表和非空循环链表如图所示:
在这里插入图片描述

🏆单循环链表的基本算法与非循环单链表的算法基本相同,只需对表尾的判断条件做出修改即可,例如,判断表尾结点的条件为:p->next==head.

🔭3.2循环链表的基本操作

在这里插入图片描述

🔎对于上述这个非空单循环链表:

✅当我们用头指针表示单循环链表:找a1的时间复杂度为:O(1),找an的时间复杂度为:O(n).
✅当我们用尾指针表示单循环链表:找a1的时间复杂度为:O(1)(R->next->next),找an的时间复杂度为:O(1)(R).
🏆因此,我们通常采用尾指针的单循环链表。

🔎3.2.1创建空表

void InitList(LNode *&rear)
{rear = new LNode;//创建头结点rear->next = rear;
}

🔎3.2.2插入操作

void InsertList(LNode *&rear, ElemType e)
{//在表尾插入一个结点LNode* s = new LNode;s->data = e;s->next = rear->next;rear->next = s;rear = s;
}

🔎3.2.3删除操作

void Delete(LNode*& rear, ElemType& e)
{//删除链表的第一个结点if (rear->next == rear)return;//空表,无法删除元素LNode* p = rear->next->next;//p指向第一个元素e = p->data;rear->next->next = p->next;if (p == rear)rear = p->next;delete p;
}

🎈4.双向链表

双向链表是在单链表的每一个结点里再增加一个指向其直接前驱的指针域prior,这样形成的链表有两个方向不同的链,故称为双向链表。
在这里插入图片描述

🔭4.1类型定义

typedef int ElemType;
typedef struct DNode
{ElemType data;//存放数据元素信息DNode* next;//存放后继结点的地址信息DNode* prior;//存放前驱结点的地址信息
}DNode;

🔭4.2头插法创建双向链表

void CreatList_h(DNode*& head, int n)
{DNode* s;head = new DNode;//创建头结点head->next = head->prior = NULL;//前后指针置为NULLint i = 0;for (i = 0; i < n; i++)//循环创建数据结点{s = new DNode;cin >> s->data;//读入数据s->next = head->next;//连接s的两个指针s->prior = head;if (head->next != NULL)head->next->prior = s;head->next = s;}
}

🔭4.3尾插法创建双向链表

void CreatList_t(DNode*& head, int n)
{DNode* s, * rear;head = new DNode;//创建头结点head->next = head->prior = NULL;//前后指针置为NULLrear = head;int i = 0;for (i = 0; i < n; i++)//循环创建数据结点{s = new DNode;//创建新的数据结点cin >> s->data;//读入数据s->prior = rear;//s插在rear后面rear->next = s;rear = s;}rear->next = NULL;
}

🔭4.4插入操作

在这里插入图片描述

void InsertDlist(DNode*& head, int i, ElemType e)
{int j = 0;//计数器DNode* p = head,*s;while (p && j < i - 1){p = p->next;j++;}if (!p || j > i - 1)return;else//找到第i-1个结点{s = new DNode;s->data = e;s->next = p->next;//p结点后插入s结点s->prior = p;if (p->next)p->next->prior = s;}
}

🔭4.5删除操作

DeleteDList()函数在双向链表中,结点的删除操作涉及前驱结点和后继结点两个指针域的变化。设在双向链表中删除指针p所指向结点的后继结点q,需要修改两个指针域,删除操作指针变化过程如图所示:
在这里插入图片描述

void DeleteDList(DNode*& head, int i, ElemType& e)
{int j = 0;//计数器DNode* p = head, * q;while (p->next && j < i - 1){p = p->next;j++;}if (!(p->next) || j > i - 1)return;else{q = p->next;e = q->data;p->next = q->next;//删除q所指结点if (q->next != NULL)q->next->prior = p;delete q;}
}

好啦,关于循环链表和双向链表的知识点到这里就结束啦,后期会继续更新数据结构与算法的相关知识,欢迎大家持续关注、点赞和评论!❤️❤️❤️

http://www.yayakq.cn/news/188497/

相关文章:

  • 网站后期维护需要怎么做怎么做像小刀网一样的网站
  • 网站建设中数据安全研究手机百度网页版入口
  • 网站制作设计专业公司广州网站优化方案
  • 展示型网站系统中小型网站建设
  • 不会写代码怎样做网站永康电子商务网站建设公司
  • 手机百度关键词排名 seo网站优化软件网页制作背景图
  • 网站建设准备期对应网站新密做网站优化
  • 房地产 网站 案例设计wordpress页面模板
  • 深圳专业网站制作多少钱可以做头像的网站
  • 南宁网站优化排名推广织梦做的网站怎么样
  • 专业苏州网站建设公司哪家好网络营销外包好处
  • 宁波做网站 主觉文化自建网站做外贸
  • 在线流程图网站怎么做网站改备案信息吗
  • 江苏高效网站制作公司建网站 几个链接
  • wordpress 建站公司收费网站必须备案吗
  • 网站维护是什么专业网站开发推进计划表
  • 交流建设网站做网站需要哪些参考文献
  • 广西建设厅微信网站云服务器建立wordpress
  • 平台式网站模板下载地址内蒙古网站seo优化
  • mui做wap网站做网站建设的怎么赢利
  • 建网站找那家好有没有在线辅导家做的网站
  • 做网站项目流程图模板做网站阿里云记录值怎么填
  • 贵阳专用网站建设做钓鱼网站获利3万
  • 一家专做土特产的网站太原模板建站系统
  • 网站建设pdf下载百度商桥的代码放到网站里
  • 品牌网站制作公司宣传广告制作效果图
  • 商城网站设计目标婚纱网站目录优化
  • 做网站需要什么系统最火的网页游戏排行榜
  • 大安网站建设鞍山市残疾人网站开发
  • 自己做的网站很卡建设单位网站的重要性