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

现在什么行业发展前景最好一个新网站怎么做seo

现在什么行业发展前景最好,一个新网站怎么做seo,企业网站的管理系统,黑龙江公司网站建设目录 一、双向带头循环链表概述 1.什么是双向带头循环链表 2.双向带头循环链表的优势 3.双向带头循环链表简图 二、双向带头循环链表的增删查改图解及代码实现 1.双向带头循环链表的头插 2.双向带头循环链表的尾插 3.双向带头循环链表的头删 4.双向带头循环链表的尾删…

目录

一、双向带头循环链表概述

1.什么是双向带头循环链表

2.双向带头循环链表的优势

3.双向带头循环链表简图

二、双向带头循环链表的增删查改图解及代码实现

1.双向带头循环链表的头插

2.双向带头循环链表的尾插

3.双向带头循环链表的头删

4.双向带头循环链表的尾删

5.双向带头循环链表在pos位置前插入节点

6.双向带头循环链表删除pos位置节点


一、双向带头循环链表概述

1.什么是双向带头循环链表

        双向:每个节点都带有一个指向下一个节点的指针(next)和一个直向前一个节点的指针(prev);

        带头:即链表带有哨兵位头节点,该节点只包含两个指针,不存储有效数据;

        循环:哨兵位头节点有一个next指针指向第一个有效数据节点,还有一个prev指针指向哨兵位节点的前一个节点即链表的尾节点,因此实现了链表的循环;

        双向带头循环链表的节点类型:

typedef int LTDataType;
typedef struct ListNode
{LTDataType data;struct ListNode* next;struct ListNode* prev;
}ListNode;

2.双向带头循环链表的优势

        双向带头循环链表不需要我们遍历每个节点来找尾节点,对于链表的尾插而言就变得非常简单。由于较单向非循环链表而言,双向带头循环链表多了一个指向前一个节点的指针prev,所以在结构上较为复杂,但实际应用中少了很多的麻烦。

3.双向带头循环链表简图

 

二、双向带头循环链表的增删查改图解及代码实现

1.双向带头循环链表的头插

示意图:

代码实现:

// 双向链表头插
void ListPushFront(ListNode* pHead, LTDataType x)
{assert(pHead);ListNode* NewNode = Node_New(x);ListNode* First = pHead->next;NewNode->next = First;First->prev = NewNode;NewNode->prev = pHead;pHead->next = NewNode;
}

2.双向带头循环链表的尾插

示意图:

代码实现:

// 双向链表尾插
void ListPushBack(ListNode* pHead, LTDataType x)
{assert(pHead);ListNode* NewNode = Node_New(x);ListNode* Tail = pHead->prev;NewNode->prev = Tail;Tail->next = NewNode;NewNode->next = pHead;pHead->prev = NewNode;
}

3.双向带头循环链表的头删

示意图:

代码实现:

// 双向链表头删
void ListPopFront(ListNode* pHead)
{assert(pHead);if (pHead->next == pHead){return;}ListNode* First = pHead->next;ListNode* Next = First->next;pHead->next = Next;Next->prev = pHead;free(First);First = NULL;
}

4.双向带头循环链表的尾删

示意图:

代码实现:

// 双向链表尾删
void ListPopBack(ListNode* pHead)
{assert(pHead);if (pHead->next == pHead){return;}ListNode* Tail = pHead->prev;ListNode* Prev = Tail->prev;Prev->next = pHead;pHead->prev = Prev;free(Tail);Tail = NULL;
}

5.双向带头循环链表在pos位置前插入节点

示意图:

代码实现:

// 双向链表在pos位置的前面插入节点
void ListInsert(ListNode* pos, LTDataType x)
{ListNode* NewNode = Node_New(x);ListNode* Prev = pos->prev;Prev->next = NewNode;NewNode->prev = Prev;NewNode->next = pos;pos->prev = NewNode;
}

6.双向带头循环链表删除pos位置节点

示意图:

代码实现:

// 双向链表删除pos位置的节点
void ListErase(ListNode* pos)
{ListNode* Prev = pos->prev;ListNode* Hind = pos->next;Prev->next = Hind;Hind->prev = Prev;free(pos);pos = NULL;
}

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

相关文章:

  • html网站设计论文app开发费用
  • 赣榆哪里有做网站的电子商务网站规划设计方案
  • 青海网网站建设dedecms是什么
  • 做a手机视频在线观看网站做音乐网站赚钱吗
  • 高邮城乡建设局网站网站建设培训 南宁
  • 全网网站建设优化网站建设与维护论文
  • 电子商务网站开发实践软件开发学什么
  • 采集网站后台数据seo在线教学
  • 做网站需要的素材照片wordpress meta query
  • 南昌商城网站建设公司wordpress tw
  • 如何建立网站的英文版摄影网站哪个最好
  • 京东建设网站的意义3d效果图制作公司
  • 视网站亏损了为什么还做成都网站建设平台
  • 学做网站知识天津网站搜索排名优化
  • 公司建站模版企业网站建设的文章
  • 河北保定建设工程信息网站定向推广
  • 淄博网站建设-中国互联网站轮播图怎么保存
  • 有实力的网站建设公司北京建筑设计网站
  • wordpress博客导航开源主题襄阳百度seo
  • ps做网站需要几个画布wordpress注册协议
  • 正常做网站多少钱装修网页设计
  • 如何管理好一个网站我想给图书网站做代理
  • 厦门网站开发公司大同网站建设
  • 潮州住房和城乡建设局网站自适应手机网站开发
  • 蓝色的网站登录页面模版搜索引擎营销的基本过程
  • 广州怎么做网站wordpress 页面禁止评论
  • 濮阳网站网站的宣传方法有哪些
  • 上杭网站建设公司关键词怎么写
  • 网站加载效果怎么做的大同推广型网站建设
  • php视频网站怎么做线上销售培训班课程