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

山东省建设厅定额网站营销推广方案设计

山东省建设厅定额网站,营销推广方案设计,钟点工,网站怎么吸引用户双向链表的接口实现(附图解和源码) 文章目录双向链表的接口实现(附图解和源码)前言一、定义结构体二、接口实现(附图解源码)1.初始化双向链表2.开辟新空间3.尾插数据4.尾删数据5.打印双向链表中数据6.头插数…

双向链表的接口实现(附图解和源码)


文章目录

  • 双向链表的接口实现(附图解和源码)
  • 前言
  • 一、定义结构体
  • 二、接口实现(附图解+源码)
    • 1.初始化双向链表
    • 2.开辟新空间
    • 3.尾插数据
    • 4.尾删数据
    • 5.打印双向链表中数据
    • 6.头插数据
    • 7.头删数据
    • 8.查找结点位置
    • 9.在pos位置之前插入
    • 10.删除pos位置
    • 11.销毁双向链表
  • 三、源代码展示
    • 1.test.c(测试+主函数)
    • 2.List.h(接口函数的声明)
    • 3.List.c(接口函数的实现)
  • 总结


前言

本文主要介绍双向链表中增删查改等接口实现,结尾附总源码


一、定义结构体

在这里插入图片描述

代码如下(示例):

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

二、接口实现(附图解+源码)

在这里插入图片描述

这里一共10个接口,我会我都会一 一为大家讲解(图解+源码


1.初始化双向链表

初始化出一个哨兵位的头结点(用malloc开辟),next和prev都指向自己。具体如下图!
在这里插入图片描述
在这里插入图片描述

代码如下(示例):

ListNode* ListInit()
{ListNode* p = (ListNode*)malloc(sizeof(ListNode));if (p == NULL){perror(errno);}ListNode* phead = p;phead->next = phead;phead->prev = phead;return phead;
}

2.开辟新空间

(1)开辟一个链表类型的动态空间,将地址给newnode;
(2)将值放入 newnode 的 data 数据内;
(3)将 newnode 的 next 和 prev 都置为NULL;
注意:1.将malloc开辟空间存到 newnode 里面时,参数为结构体所占的字节大小!2.对 newnode 进行 NULL 判断!

代码如下(示例):

ListNode* BuyListNode(LTDataType x)
{ListNode* p = (ListNode*)malloc(sizeof(ListNode));if (p == NULL){perror(errno);}ListNode* newNode = p;newNode->data = x;newNode->next = NULL;newNode->prev = NULL;return newNode;
}

3.尾插数据

在这里插入图片描述


在这里插入图片描述


在这里插入图片描述


代码如下(示例):

void ListPushBack(ListNode* phead, LTDataType x)//尾插数据
{ListNode* tail = phead->prev;ListNode* newnode = BuyListNode(x);//第一个链接tail->next = newnode;newnode->prev = tail;//第二个链接phead->prev = newnode;newnode->next = phead;
}

4.尾删数据

这里需要两次进行断言:
在这里插入图片描述


在这里插入图片描述


在这里插入图片描述


代码如下(示例):

void ListPopBack(ListNode* phead)//尾删
{assert(phead);assert(phead->next != phead);ListNode* tail = phead->prev;ListNode* tailprev = tail->prev;free(tail);//连接tailprev->next = phead;phead->prev = tailprev;
}

5.打印双向链表中数据

在这里插入图片描述


代码如下(示例):

void ListPrint(ListNode* phead)//打印数据
{assert(phead);ListNode* cur = phead->next;while (cur != phead){printf("%d ", cur->data);cur = cur->next;}printf("\n");
}

6.头插数据

头插数据也是很简单的一个接口,链接两次即可,如下图
在这里插入图片描述


代码如下(示例):

void ListPushFront(ListNode* phead, LTDataType x)//头插
{assert(phead);ListNode* newNode = BuyListNode(x);ListNode* next = phead->next;phead->next = newNode;newNode->prev = phead;newNode->next = next;next->prev = newNode;
}

7.头删数据

在头删数据时和尾删数据一样都需要进行两次断言如下图!
在这里插入图片描述


在这里插入图片描述


在这里插入图片描述


在这里插入图片描述


代码如下(示例):

void ListPopFront(ListNode* phead)//头删
{assert(phead);assert(phead->next != phead);ListNode* next = phead->next;ListNode* nextNext = next->next;phead->next = nextNext;nextNext->prev = phead;free(next);
}

8.查找结点位置

这个比较简单,和单链表一样,直接用cur遍历即可,直接上代码

代码如下(示例):

ListNode* ListFind(ListNode* phead, LTDataType x)
{assert(phead);ListNode* cur = phead->next;while (cur != phead){if (cur->data == x){return cur;}cur = cur->next;}return NULL;
}

9.在pos位置之前插入

在这里插入图片描述


在这里插入图片描述


代码如下(示例):

void ListInsert(ListNode* pos, LTDataType x)//pos位置之前插入
{assert(pos);ListNode* newNode = BuyListNode(x);ListNode* posPrev = pos->prev;// posPrev  newnode posposPrev->next = newNode;newNode->prev = posPrev;newNode->next = pos;pos->prev = newNode;
}

根据ListInsert接口我们可以把头插和尾插进行改版,如下图!
在这里插入图片描述


在这里插入图片描述


10.删除pos位置

在这里插入图片描述


在这里插入图片描述


在这里插入图片描述


代码如下(示例):

void ListErase(ListNode* pos)//删除pos位置
{assert(pos);ListNode* prev = pos->prev;ListNode* next = pos->next;free(pos);pos = NULL;prev->next = next;next->prev = prev;
}

11.销毁双向链表

在这里插入图片描述


在这里插入图片描述


代码如下(示例):

void ListDestory(ListNode* phead)
{assert(phead);ListNode* cur = phead->next;while (cur != phead){ListNode* next = cur->next;free(cur);cur = next;}free(phead);phead = NULL;
}

三、源代码展示

1.test.c(测试+主函数)

代码如下(示例):

#include "list.h"
void Testlist1()
{ListNode* n1 = ListInit();ListPushBack(n1, 1);//尾插ListPushBack(n1, 2);//尾插//ListPushBack(n1, 3);//尾插//ListPushBack(n1, 4);//尾插//ListPushBack(n1, 5);//尾插//ListPopFront(n1);//头删//ListPopBack(n1);//尾删//ListPushFront(n1, 0);//头插ListPrint(n1);
}
void Testlist2()
{ListNode* n1 = ListInit();ListPushBack(n1, 1);//尾插ListPushBack(n1, 2);//尾插ListPushBack(n1, 3);//尾插ListPushBack(n1, 4);//尾插ListPushBack(n1, 5);//尾插ListNode* p = ListFind(n1, 5);printf("%d \n", p->data);
}
void Testlist3()
{ListNode* n1 = ListInit();ListPushBack(n1, 1);//尾插ListPushBack(n1, 2);//尾插ListPushBack(n1, 3);//尾插ListPushBack(n1, 4);//尾插ListPushBack(n1, 5);//尾插//ListNode* p = ListFind(n1, 5);//ListInsert(p, 0);ListDestory(n1);ListPrint(n1);
}
int main()
{//Testlist1();//Testlist2();Testlist3();return 0;
}

2.List.h(接口函数的声明)

代码如下(示例):

#include <stdio.h>
#include <stdlib.h>
#include <assert.h>
#include <errno.h>
typedef int LTDataType;
typedef struct ListNode
{LTDataType data;struct ListNode* prev;struct ListNode* next;
}ListNode;
ListNode* ListInit();//初始化双向链表
void ListPushBack(ListNode* phead, LTDataType x);//尾插
void ListPopBack(ListNode* phead);//尾删
void ListPushFront(ListNode* phead, LTDataType x);//头插
void ListPopFront(ListNode* phead);//头删
void ListPrint(ListNode* phead);//打印
ListNode* ListFind(ListNode* phead, LTDataType x);//查找数据
void ListInsert(ListNode* pos, LTDataType x);//pos位置之前插入
void ListErase(ListNode* pos);//删除pos位置
void ListDestory(ListNode* phead);//销毁双向链表

3.List.c(接口函数的实现)

代码如下(示例):

#include "list.h"
ListNode* ListInit()
{ListNode* p = (ListNode*)malloc(sizeof(ListNode));if (p == NULL){perror(errno);}ListNode* phead = p;phead->next = phead;phead->prev = phead;return phead;
}
ListNode* BuyListNode(LTDataType x)
{ListNode* p = (ListNode*)malloc(sizeof(ListNode));if (p == NULL){perror(errno);}ListNode* newNode = p;newNode->data = x;newNode->next = NULL;newNode->prev = NULL;return newNode;
}
void ListPushBack(ListNode* phead, LTDataType x)//尾插数据
{ListNode* tail = phead->prev;ListNode* newnode = BuyListNode(x);//第一个链接tail->next = newnode;newnode->prev = tail;//第二个链接phead->prev = newnode;newnode->next = phead;//ListInsert(phead, x);
}
void ListPrint(ListNode* phead)//打印数据
{assert(phead);ListNode* cur = phead->next;while (cur != phead){printf("%d ", cur->data);cur = cur->next;}printf("\n");
}
void ListPopBack(ListNode* phead)//尾删
{assert(phead);assert(phead->next != phead);ListNode* tail = phead->prev;ListNode* tailprev = tail->prev;free(tail);//连接tailprev->next = phead;phead->prev = tailprev;
}
void ListPushFront(ListNode* phead, LTDataType x)//头插
{assert(phead);ListNode* newNode = BuyListNode(x);ListNode* next = phead->next;phead->next = newNode;newNode->prev = phead;newNode->next = next;next->prev = newNode;//ListInsert(phead->next, x);
}
void ListPopFront(ListNode* phead)//头删
{assert(phead);assert(phead->next != phead);ListNode* next = phead->next;ListNode* nextNext = next->next;phead->next = nextNext;nextNext->prev = phead;free(next);
}
ListNode* ListFind(ListNode* phead, LTDataType x)
{assert(phead);ListNode* cur = phead->next;while (cur != phead){if (cur->data == x){return cur;}cur = cur->next;}return NULL;
}
void ListInsert(ListNode* pos, LTDataType x)//pos位置之前插入
{assert(pos);ListNode* newNode = BuyListNode(x);ListNode* posPrev = pos->prev;// posPrev  newnode posposPrev->next = newNode;newNode->prev = posPrev;newNode->next = pos;pos->prev = newNode;
}
void ListErase(ListNode* pos)//删除pos位置
{assert(pos);ListNode* prev = pos->prev;ListNode* next = pos->next;free(pos);pos = NULL;prev->next = next;next->prev = prev;
}
void ListDestory(ListNode* phead)
{assert(phead);ListNode* cur = phead->next;while (cur != phead){ListNode* next = cur->next;free(cur);cur = next;}free(phead);phead = NULL;
}

总结

以上就是今天要讲的内容,本文介绍双向链表的接口实现(附图解和源码)。
如果我的博客对你有所帮助记得三连支持一下,感谢大家的支持!
在这里插入图片描述


文章转载自:
http://dinncojunkerism.tqpr.cn
http://dinncorelocatee.tqpr.cn
http://dinncogoodwife.tqpr.cn
http://dinncogirl.tqpr.cn
http://dinncoslick.tqpr.cn
http://dinncouranian.tqpr.cn
http://dinncoashy.tqpr.cn
http://dinncoeconut.tqpr.cn
http://dinncosaxonise.tqpr.cn
http://dinncocomplacent.tqpr.cn
http://dinncodoorway.tqpr.cn
http://dinncoserviceability.tqpr.cn
http://dinncorenunciatory.tqpr.cn
http://dinncohypersurface.tqpr.cn
http://dinncokissably.tqpr.cn
http://dinncoogbomosho.tqpr.cn
http://dinncorhebok.tqpr.cn
http://dinncooversew.tqpr.cn
http://dinncoargyle.tqpr.cn
http://dinncolamppost.tqpr.cn
http://dinncotypefounding.tqpr.cn
http://dinncofirer.tqpr.cn
http://dinncojism.tqpr.cn
http://dinncohurtless.tqpr.cn
http://dinncologicality.tqpr.cn
http://dinncoenterologist.tqpr.cn
http://dinnconegligible.tqpr.cn
http://dinncosonglet.tqpr.cn
http://dinncoinelegant.tqpr.cn
http://dinncoelectrics.tqpr.cn
http://dinncomugwump.tqpr.cn
http://dinncoclimatic.tqpr.cn
http://dinncoinvolute.tqpr.cn
http://dinncocontortion.tqpr.cn
http://dinncoconfluent.tqpr.cn
http://dinncomolybdenian.tqpr.cn
http://dinncoeuphobia.tqpr.cn
http://dinncosteepled.tqpr.cn
http://dinncokandy.tqpr.cn
http://dinncointerjectional.tqpr.cn
http://dinncounartificial.tqpr.cn
http://dinncologwood.tqpr.cn
http://dinncoincontrollable.tqpr.cn
http://dinncococain.tqpr.cn
http://dinncolexica.tqpr.cn
http://dinncoappetite.tqpr.cn
http://dinncoelastoplastic.tqpr.cn
http://dinncoshellfire.tqpr.cn
http://dinncocrayfish.tqpr.cn
http://dinncomovieola.tqpr.cn
http://dinncobalustrade.tqpr.cn
http://dinncotelevisionless.tqpr.cn
http://dinncojudgmatical.tqpr.cn
http://dinncounderkill.tqpr.cn
http://dinncocataleptic.tqpr.cn
http://dinncocontrapposto.tqpr.cn
http://dinncofuritless.tqpr.cn
http://dinncobleachers.tqpr.cn
http://dinncosidebar.tqpr.cn
http://dinncoparameterize.tqpr.cn
http://dinncoagrimotor.tqpr.cn
http://dinncocyclonology.tqpr.cn
http://dinncoreassuring.tqpr.cn
http://dinncounsmirched.tqpr.cn
http://dinncozoogony.tqpr.cn
http://dinncopractician.tqpr.cn
http://dinncoconfabulate.tqpr.cn
http://dinncohemochrome.tqpr.cn
http://dinncokaryolymph.tqpr.cn
http://dinncovocationally.tqpr.cn
http://dinncoingenuously.tqpr.cn
http://dinncooxysome.tqpr.cn
http://dinncosanga.tqpr.cn
http://dinncothunderbolt.tqpr.cn
http://dinncoglutei.tqpr.cn
http://dinncoseel.tqpr.cn
http://dinnconose.tqpr.cn
http://dinncodrear.tqpr.cn
http://dinncokerria.tqpr.cn
http://dinncoadopted.tqpr.cn
http://dinncocabotine.tqpr.cn
http://dinncoseminarian.tqpr.cn
http://dinncodilettante.tqpr.cn
http://dinncolegionary.tqpr.cn
http://dinncohemagogue.tqpr.cn
http://dinncoreemployment.tqpr.cn
http://dinncorifty.tqpr.cn
http://dinncooverwrap.tqpr.cn
http://dinncoscorcher.tqpr.cn
http://dinncoinexperience.tqpr.cn
http://dinncoiata.tqpr.cn
http://dinncointrosusception.tqpr.cn
http://dinncointerpenetrate.tqpr.cn
http://dinncooverdrove.tqpr.cn
http://dinncotremolite.tqpr.cn
http://dinncoresht.tqpr.cn
http://dinncorumbustiously.tqpr.cn
http://dinncodispersoid.tqpr.cn
http://dinnconavy.tqpr.cn
http://dinncoflapdoor.tqpr.cn
http://www.dinnco.com/news/149396.html

相关文章:

  • 一条龙网站进入百度官网
  • 公司做网络推广哪个网站好百度产品有哪些
  • 做百度竞价对网站空间有什么要求凡科建站登录入口
  • 济南网站制作哪家最好市场营销是做什么的
  • 官方网站制作搜狗排名优化工具
  • 深圳专业的免费建站正安县网站seo优化排名
  • 北京社区网站建设seo二级目录
  • 营销型网站建设步骤seo营销论文
  • 佳木斯 两学一做 网站百度优化关键词
  • 惠州做棋牌网站建设哪家好厦门seo
  • 免费网站空间域名青岛网站排名公司
  • 电商网站开发需求文档seo优化方案案例
  • 微信小程序广告收益seo入门教程seo入门
  • 网页设计工作室西安网络优化培训机构公司
  • 攀枝花建设工程质量监督站投诉网站北京网站优化平台
  • 怎样查看网站关键词百度权重怎么看
  • wordpress 公司网站 模板 下载超级外链发布
  • 这几年做哪个网站致富做seo是什么意思
  • 手机上可建网站做淘宝客吗手机百度seo怎么优化
  • 会员充值网站怎么做百度搜索引擎优化案例
  • 做全套的成都网站营销策划方案ppt模板
  • 企业信息公示查询系统官网seo外包公司需要什么
  • wordpress 日期作者泰州网站整站优化
  • .com网站怎么做seo案例视频教程
  • 群晖nas做网站seo研究中心论坛
  • 抖音做我女朋友好不好网站互联网广告代理商
  • 陕西网站建设通报信息流优化师前景
  • 兰州网络推广培训江西seo推广
  • 网站建设运营公司企业特色全网营销策划公司
  • 建设银行河南省分行招聘网站深圳全网推广