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

做网站后台程序是怎么来的百度云登陆首页

做网站后台程序是怎么来的,百度云登陆首页,住房建设局网站首页,智慧团建重置密码验证码List.h 相较于之前的顺序表和单向链表&#xff0c;双向链表的逻辑结构稍微复杂一些&#xff0c;但是在实现各种接口的时候是很简单的。因为不用找尾&#xff0c;写起来会舒服一点。&#xff08;也可能是因为最近一直在写这个的原因&#xff09; #pragma once #include<std…

List.h

相较于之前的顺序表和单向链表,双向链表的逻辑结构稍微复杂一些,但是在实现各种接口的时候是很简单的。因为不用找尾,写起来会舒服一点。(也可能是因为最近一直在写这个的原因)

#pragma once
#include<stdio.h>
#include<assert.h>
#include<stdlib.h>
#include<stdbool.h>typedef int LTDataType;
typedef struct ListNode
{struct ListNode* prev;LTDataType data;struct ListNode* next;}LTNode;LTNode* LTInit();
void LTDestroy(LTNode* phead);
void LTPrint(LTNode* phead);
//bool LTEmpty(LTNode* phead);void LTPushBack(LTNode* phead, LTDataType x);
void LTPopBack(LTNode* phead);void LTPushFront(LTNode* phead, LTDataType x);
void LTPopFront(LTNode* phead);
//在pos位置之后插入数据
void LTInsert(LTNode* pos, LTDataType x);
void LTErase(LTNode* pos);
LTNode* LTFind(LTNode* phead, LTDataType x);

List.c

在实现接口的时候,除了没有找尾,其他的操作和单向链表是差不多的,这里就不多说了。(注意代码里的注释)

#define _CRT_SECURE_NO_WARNINGS 1#include"List.h"LTNode* BuyNode(LTDataType x)
{LTNode* node = (LTNode*)malloc(sizeof(LTNode));if (node == NULL){perror("malloc is fail!");exit(1);}node->data = x;node->prev = node->next = node;return node;
}LTNode* LTInit()
{LTNode* phead = BuyNode(-1);return phead;
}void LTPrint(LTNode* phead)
{assert(phead);LTNode* pcur = phead->next;while (pcur != phead){printf("%d->",pcur->data);pcur = pcur->next;}printf("\n");//注意换行
}void LTPushBack(LTNode* phead, LTDataType x)
{assert(phead);LTNode* newnode = BuyNode(x);newnode->prev = phead->prev;newnode->next = phead;newnode->prev->next = newnode;phead->prev = newnode;
}void LTPopBack(LTNode* phead)
{assert(phead && phead->next != phead);//第二个很容易忽视!LTNode* del = phead->prev;del->prev->next = phead;phead->prev = del->prev;free(del);del = NULL;
}void LTPushFront(LTNode* phead, LTDataType x)
{assert(phead);LTNode* newnode = BuyNode(x);phead->next->prev = newnode;newnode->next = phead->next;phead->next = newnode;newnode->prev = phead;
}void LTPopFront(LTNode* phead)
{assert(phead && phead->next != phead);LTNode* del = phead->next;del->next->prev = phead;phead->next = del->next;free(del);del = NULL;
}LTNode* LTFind(LTNode* phead, LTDataType x)
{assert(phead && phead->next != phead);LTNode* pcur = phead->next;while (pcur != phead){if (pcur->data == x)//别忘了连等号!!!return pcur;pcur = pcur->next;}return NULL;
}void LTErase(LTNode* pos)
{assert(pos);pos->next->prev = pos->prev;pos->prev->next = pos->next;free(pos);pos = NULL;
}void LTInsert(LTNode* pos, LTDataType x)
{assert(pos);LTNode* newnode = BuyNode(x);pos->next->prev = newnode;newnode->next = pos->next;newnode->prev = pos;pos->next = newnode;
}void LTDestroy(LTNode* phead)//理论上这里应该传二级指针,但是为了保持接口的一致性,用一级。
{assert(phead);LTNode* des = phead->next;while (des != phead){LTNode* next = des->next;free(des);des = next;}free(phead);phead = des = NULL;
}

本博客旨在记录学习过程,以后忘了随时来看。

http://www.hrbkazy.com/news/56798.html

相关文章:

  • 中铁建设集团公司门户重庆百度推广seo
  • 购物网站建设合同公司官网制作开发
  • 苏宁易购的网站建设百度客服24小时人工服务
  • 网站制作公司杭州市场推广方法
  • 广西网站建设工具seo sem是什么职位
  • 长沙哪里有专业做网站seo网络营销技术
  • 几年做啥网站能致富推广小程序拿佣金
  • 新商盟显示 检查网站开发错误呢网站seo分析报告
  • 网站建设仟金手指六六14友情链接交易网站
  • 太原网站建设的公司排名如何进行网络推广和宣传
  • h5css3做网站首页网络推广员要怎么做
  • 做商贸网站网站链接提交收录
  • 公司做网站需要哪些资料全球外贸采购网
  • qqip.探测网站建设网络推广是什么
  • 个人动态网页制作的方法郑州seo线上推广系统
  • 网站主机域名百度云盘搜索引擎入口
  • 武昌做网站jw100东莞疫情最新消息今天新增
  • 有什么网站可以做投票seo学堂
  • 备案网站刷移动关键词优化
  • 外贸有哪些网站网络营销模式案例
  • 做外贸网站服务软件推广怎么赚钱
  • 柳市建设网站今日中央新闻
  • php新闻网站源码靠谱的广告联盟
  • 做网站采集seo网络推广培训班
  • 云南网站建设500社群推广平台
  • 水资源论证网站建设免费创建个人网站
  • nh网站建设抖音seo软件
  • 哪些网站可以做店铺推广网站搜索引擎优化报告
  • 品牌形象网站有哪些百度推广seo怎么学
  • 班级网页设计素材seo入门培训学校