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

关于纪委网站建设的建议关联词有哪些五年级

关于纪委网站建设的建议,关联词有哪些五年级,网站建设需要多少钱小江网页设计,wordpress不能后台前言: 链表有很多种,上一章结,我复盘了单链表,这一章节,主要针对双链表的知识点进行,整理复盘,如果将链表分类的话,有很多种,我就学习的方向考察的重点,主要…

前言:

链表有很多种,上一章结,我复盘了单链表,这一章节,主要针对双链表的知识点进行,整理复盘,如果将链表分类的话,有很多种,我就学习的方向考察的重点,主要针对这两种链表进行整理。

带头双向循环链表:结构最复杂,一般用在单独存储数据。实际中使用的链表数据结构,都是带头双向循环链表。另外这个结构虽然结构复杂,但是使用代码实现以后会发现结构会带来很多优势,实现反而简单了,后面我们代码实现了就知道了。带头双向循环链表如下图所示。 

 


目录

1. 带头双向链表的实现

 1.1封装链表节点结构体

1.2建立新的节点 

 1.3初始化链表

1.4尾插函数 

 1.5尾删

 1.6头插

1.7头删

1.8显示

1.9销毁

1.10查找

1.11插入

1.12擦除

1.13判空


 

1. 带头双向链表的实现

 1.1封装链表节点结构体

typedef int LDataType;typedef struct ListNode
{LDataType data;//自身数据struct ListNode* prev;指向前一个节点指针struct ListNode* next;指向后一个节点指针}LTNode;

1.2建立新的节点 

 链表的增删查改都会有新的节点,所以我们可以封装一个建立节点的函数,具体代码如下:

LTNode* BuyNode(LDataType x)
{LTNode* temp = (LTNode*)malloc(sizeof(LTNode));if (temp == NULL){perror("malloc:fail");exit(-1);}temp->data = x;temp->next = NULL;temp->prev = NULL;return temp;
}

 1.3初始化链表

 因为是带头节点,初始化会改变节点指向,如果按照单链表的操作习惯,我们可能穿指针变量的地址,用二级指针接收,但是也没必要,我们可以让函数返回的类型,为指针,具体代码如下:

LTNode* ListInit()
{LTNode* phead = BuyNode(-1);phead->next = phead;phead->prev = phead;return phead;
}

1.4尾插函数 

 因为头结点的prev指向tail,tail的next节点指向head所以我们只要改变节点指向就可以完成尾插,如图所示:

具体代码如下: 

void PushBack(LTNode* pa, LDataType x)
{assert(pa);LTNode* newnode = BuyNode(x);LTNode* tail = pa->prev;tail->next = newnode;newnode->prev = tail;pa->prev = newnode;newnode->next = pa;}

 1.5尾删

 删掉最后一个节点,并改变节点指向

具体代码如下:

void PopBack(LTNode* pa)
{assert(pa);LTNode* tail = pa->prev;LTNode* middle = tail->prev;middle->next = pa;pa->prev = middle;free(tail);tail = NULL;}

 1.6头插

 

代码如下:

void PushFront(LTNode* pa, LDataType x)
{assert(pa);LTNode* newnode = BuyNode(x);LTNode* middle = pa->next;newnode->next = middle;middle->prev = newnode;pa->next = newnode;newnode->prev = pa;
}

1.7头删

 代码如下

void PopFront(LTNode* pa)
{assert(pa);LTNode* middle = pa->next;LTNode* cur = middle->next;pa->next = cur;cur->prev = pa;free(middle);middle = NULL;
}

1.8显示

 增删查改之后,需要显示在终端,所以要有打印显示函数

void ListPrint(LTNode* pa)
{LTNode* cur = pa->next;while (cur != pa) {printf("%d<=>", cur->data);cur = cur->next;}printf("NULL\n");
}

1.9销毁

 在堆上创建的空间,使用完成后,要返还给操作系统。

void ListDestroy(LTNode* pa)
{LTNode* cur = pa->next;LTNode* prev = NULL;while (cur != pa){LTNode* prev = cur;cur = cur->next;free(prev);}free(pa);pa->next = pa->prev = NULL;
}

1.10查找

 查找指定数值得节点,当查找到的时候返回该数值得地址,如果没有查找到则返回空指针。

LTNode* ListFind(LTNode* pa, LDataType x)
{assert(pa);LTNode* cur = pa->next;while (cur != pa){if (cur->data != x){cur = cur->next;}else{return cur;}}return NULL;}

1.11插入

 在当前节点的前一个位置插入节点

void ListInsert(LTNode* pa, LTNode* pos, LDataType x)
{assert(pa);assert(pos);LTNode* newnode = BuyNode(x);LTNode* prev = pos->prev;newnode->next = pos;pos->prev = newnode;prev->next = newnode;newnode->prev = prev;}

1.12擦除

 将当前节点去除掉。

void ListErase(LTNode* pa, LTNode* pos)
{assert(pos);LTNode* prev = pos->prev;LTNode* next = pos->next;prev->next = next;next->prev = prev;free(pos);pos = NULL;}

1.13判空

如果头节点的下个指向为自己这个表达式为真的话,则返回true 否则返回false。 

bool LTEmpty(LTNode* pa)
{return pa->next == pa;
}

http://www.tj-hxxt.cn/news/65427.html

相关文章:

  • 做网站域名公司成都网站设计
  • 做网站公司牛鼻子关键词调词平台费用
  • 沈阳免费做网站爱站网关键词查询网站的工具
  • 公司网站 开源百度关键词排名点
  • 三门峡做网站网站如何提升seo排名
  • 科技设计网站建设南宁seo排名优化
  • 全球十大网站访问量排名最近一周新闻热点大事件
  • 网站开发组岗位营销一体化平台
  • 网站建设 有限公司中国万网域名注册服务内容
  • wordpress 音乐 页面aso优化方法
  • 深圳企业做网站公司有哪些海外互联网推广平台
  • 免费商业wordpress主题搜索引擎优化代理
  • 阿里云商业网站建设视频云和数据培训机构怎么样
  • 北京最好的网站建设公司seo网站排名推广
  • 江苏网站开发网上电商怎么做
  • 哪家做的网站有利于百度推广seo点击排名工具有用吗
  • 开发一个公众号大概需要多少钱seo泛目录培训
  • 长沙网站自己制作网站关键词排名软件推荐
  • wordpress网站加载过慢网络推广营销方法
  • 保定市人民政府网站大一html网页制作
  • 网站流量盈利常见的网站推广方法有哪些
  • 网站建设与制作德州股票发行ipo和seo是什么意思
  • 哪建设网站独立网站怎么做
  • 简述网站设计流程2023上海又出现疫情了
  • 做盗版影视网站福州外包seo公司
  • 网站建设数据库怎么弄合肥网络推广网络运营
  • 网站绑定微信公众号网络最有效的推广方法
  • 一个网站的建设需要哪些流程旅游新闻热点
  • 广东汽车品牌网站建设网址大全名称
  • 网站续费话术济南网站建设老威