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

企业网站源码cmshexo wordpress哪个好

企业网站源码cms,hexo wordpress哪个好,正版海外自媒体服务器官网,黄骅招聘信息最新2022目录 双向链表 一、结构特点 二、操作优势 三、应用场景 1.创建链表 2.头插数据 3.打印数据 4.查找数据 5.删除数据 6.更改数据 7.清空数据 8.尾插数据 9.按位插入 10.获取长度 11.是否为空 双向链表 双向链表是一种链表结构。 一、结构特点 1. 每个节点包含两个…

目录

 

双向链表

一、结构特点

二、操作优势

三、应用场景

1.创建链表

2.头插数据

3.打印数据

4.查找数据

5.删除数据

6.更改数据

7.清空数据

8.尾插数据

9.按位插入

10.获取长度

11.是否为空


 

双向链表

双向链表是一种链表结构。


一、结构特点


1. 每个节点包含两个指针,分别指向直接前驱节点和直接后继节点。这使得在双向链表中可以双向遍历,既可以向前也可以向后查找节点。
2. 相比单向链表,双向链表在某些操作上更加灵活,比如在删除节点时,可以快速找到前驱节点进行调整,而单向链表需要从头开始遍历才能找到前驱节点。


二、操作优势


1. 插入操作:可以快速确定插入位置的前后节点,进行指针调整,实现高效的插入操作。
2. 删除操作:由于能够直接访问前驱节点,删除操作也更加方便快捷。


三、应用场景


1. 需要频繁进行前后遍历的场景,如文本编辑器中对字符的双向移动和操作。
2. 对数据的插入和删除操作较多,且要求高效的系统中。

1.创建链表

LinkList *CreateLinkList()
{LinkList*ll =  (LinkList*)malloc(sizeof(LinkList));if(NULL == ll){perror("CreateLinkList malloc");return NULL;}ll->head = NULL;ll->clen = 0;return ll;
}

2.头插数据

int InsertHeadLinkList(LinkList *list, DATATYPE *data)
{LinkNode* newnode = (LinkNode*)malloc(sizeof(LinkNode));if(NULL == newnode){perror("InsertHeadLinkList malloc");return 1;}memcpy(&newnode->data,data,sizeof(DATATYPE));newnode->next = NULL;newnode->prev = NULL;if(IsEmptyLinkList(list)){list->head  = newnode;}else{newnode->next = list->head;list->head->prev = newnode;list->head = newnode;}list->clen++;return 0;
}

3.打印数据

int ShowLinkList(LinkList *list ,DIRECT dir)
{int i=0;int len =GetSizeLinkList(list);LinkNode* tmp = list->head;if(DIR_FORWARD == dir){for(i = 0 ;i<len;i++){printf("name:%s age:%d score:%d\n",tmp->data.name,tmp->data.age,tmp->data.score);tmp=tmp->next;}}else{while(tmp->next){tmp=tmp->next;}while(tmp){printf("name:%s age:%d score:%d\n",tmp->data.name,tmp->data.age,tmp->data.score);tmp=tmp->prev;}}return 0;
}

4.查找数据

LinkNode *FindLinkList(LinkList *list, char *name)
{int len = GetSizeLinkList(list);int i = 0 ;LinkNode*tmp = list->head;for(i = 0 ;i<len;i++){if(0==strcmp(tmp->data.name,name)){return tmp;}tmp=tmp->next;}return NULL;
}

5.删除数据

int DeleteLinkList(LinkList *list, char *name)
{LinkNode*tmp = FindLinkList(list,name);if(NULL == tmp){return 1;}if(tmp->next){tmp->next->prev=tmp->prev;}if(tmp->prev){tmp->prev->next = tmp->next;}else{list->head = tmp->next;}free(tmp);list->clen--;return 0;
}

6.更改数据

int ModifyLinkList(LinkList *list, char *name, DATATYPE *data)
{LinkNode* tmp = FindLinkList(list,name);if(NULL == tmp){return 1;}memcpy(&tmp->data,data,sizeof(DATATYPE));return 0;
}

7.清空数据

int DestroyLinkList(LinkList *list)
{LinkNode* tmp = list->head;while(tmp){list->head= list->head->next;free(tmp);tmp = list->head;}free(list);return 0;
}

8.尾插数据

int InsertTailLinkList(LinkList *list, DATATYPE *data)
{if(IsEmptyLinkList(list)){return InsertHeadLinkList(list,data);}else{LinkNode* newnode = (LinkNode*)malloc(sizeof(LinkNode));if(NULL == newnode){perror("inster tail malloc");return 1;}// newnode  initmemcpy(&newnode->data,data,sizeof(DATATYPE));newnode->next = NULL;newnode->prev=NULL;LinkNode*tmp = list->head;while(tmp->next){tmp = tmp->next;}newnode->prev = tmp;tmp->next = newnode;}list->clen++;return 0;
}

9.按位插入

int InsertPosLinkList(LinkList *list, DATATYPE *data, int pos) {int len = GetSizeLinkList(list);if (pos < 0 || pos > len) {return 1;}if (0 == pos) {return InsertHeadLinkList(list, data);} else if (len == pos) {return InsertTailLinkList(list, data);} else {LinkNode *tmp = list->head;int i = 0;for (i = 0; i < pos - 1; i++) {tmp = tmp->next;}LinkNode *newnode = (LinkNode *)malloc(sizeof(LinkNode));if (NULL == newnode) {perror("insert pos malloc");return 1;}memcpy(&newnode->data, data, sizeof(DATATYPE));newnode->next = NULL;newnode->prev = NULL;newnode->prev = tmp;newnode->next = tmp->next;tmp->next->prev = newnode;tmp->next = newnode;}list->clen++;return 0;
}

10.获取长度

int GetSizeLinkList(LinkList*list)
{return list->clen;
}

11.是否为空

int IsEmptyLinkList(LinkList*list)
{return 0 == list->clen;
}

 

 

 

 

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

相关文章:

  • 塑胶网站建设网站的程序有哪些内容
  • 织梦怎么做淘客网站科技创新的评价机制的作用
  • 网站格式有哪些wordpress慢数据库
  • 厦门网站排名优化价格无锡网站制作哪家公司好
  • 东营利津网站建设wordpress4绑定多个域名
  • 优秀的平面设计网站百胜网站建设
  • 简洁物流网站模板免费下载宣传片公司哪家好
  • 北京手机网站开发费用每太营销咨询
  • 建设网站需要注意什么问题怎么做公司logo
  • 福州网站设计定制公司下载asp网站
  • 随州公司做网站电子商务网站进度的基本流程
  • 有没有学做蛋糕的网站和视频威海网站建设公司哪家好
  • 河南网站设计价格标题优化怎么做
  • 如何做镜框 网站网站制作 p
  • 石家庄网站推广排名百度主页面
  • 郑州艾特软件 网站建设网页设计教程
  • idc自动续费网站源码沈阳建设工程招投标网
  • 百度收录网站要多郑州高端网站公司
  • 文山建设局网站东莞营销推广服务
  • 电脑上如何做网站宣传用php做企业网站的可行性
  • 营销型网站策划 pdf破解版WordPress主题
  • 昆明网站搭建多少钱进口彩妆做的好的网站
  • 预付网站建设费用会计分录夜狼seo
  • 怎么在阿里巴巴网站做公司仿网易考拉网站建设
  • 深圳品牌网站建设公司排名做网站需要用什么开发软件
  • 网站ppt缩略图建立有效的()
  • 海南网站建设中心深圳高端平台
  • 武进区城乡建设局网站wordpress在线题库
  • 上海官网建设昆明官网seo技术
  • 上海做网站优化哪家好免费推广网站入口2023