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

双向链表相关代码

DLinkList.h

//
//  DLinkList.hpp
//  FirstP
//
//  Created by 赫赫 on 2023/10/31.
//  双向链表相关代码:双向链表、循环双向链表#ifndef DLinkList_hpp
#define DLinkList_hpp
#include <stdio.h>
#include <stdlib.h>
#include <iostream>
#include <string>
using namespace std;#endif /* DLinkList_hpp *///双向链表结构体定义
typedef struct DLNode{int data;struct DLNode *prior,*next;
}DLNode,*DLinkList;
//DLNode *DL;
//DLinkList L;//初始化双向链表
bool initDList(DLinkList &L);//在已知的p结点后面插入newnode
bool InsertNextDNode(DLNode *p,DLNode *newnode);//在已知的p结点后面删除一个结点
bool DeleteNextDNode(DLNode *p);//简要的遍历操作
void findDNode(DLinkList &L);//------------------------------------------
//初始化循环双向链表
bool initCycleDLinkList(DLinkList &L);//判断循环双向链表为空
bool Empty(DLinkList &L);//循环双向链表中在已知结点p后面插入新节点
bool InsertNextDNodeCycle(DLNode *p,DLNode *newnode);//循环双向链表中删除已知结点p
bool DeleteDNodeCycle(DLNode *p);

DLinkList.cpp

//
//  DLinkList.cpp
//  FirstP
//
//  Created by 赫赫 on 2023/10/31.
//#include "DLinkList.hpp"//初始化双向链表
bool initDList(DLinkList &L){//创建头结点L=(DLNode *)malloc(sizeof(DLNode));if(L==NULL){//内存不足,创建失败return false;}L->prior=NULL;//头结点的前驱指针永远指向NULLL->next=NULL;return true;
}//在已知的p结点后面插入newnode
bool InsertNextDNode(DLNode *p,DLNode *newnode){if(p==NULL||newnode==NULL){return false;}//结点插入操作newnode->next=p->next;newnode->prior=p;if(p->next!=NULL){p->next->prior=newnode;}p->next=newnode;return true;
}//在已知的p结点后面删除一个结点
bool DeleteNextDNode(DLNode *p){if(p==NULL){return false;}DLNode *q=p->next;if(q==NULL){return false;}p->next=q->next;if(q->next!=NULL){q->next->prior=p;}free(q);return true;
}//简要的遍历操作
void findDNode(DLinkList &L){DLNode *p=L;//正序遍历while(p!=NULL){p=p->next;}//前向遍历(跳过对头结点的操作)while(p->prior!=NULL){p=p->prior;}//前向遍历(不带头结点的包含对头结点的操作)while(p!=NULL){p=p->prior;}
}//------------------------------------------
//初始化循环双向链表
bool initCycleDLinkList(DLinkList &L){L=(DLNode*)malloc(sizeof(DLNode));if(L==NULL){return false;}L->prior=L;L->next=L;return true;
}//判断循环双向链表为空
bool Empty(DLinkList &L){if(L->next==L){return true;}else{return false;}
}//循环双向链表中在已知结点p后面插入新节点
bool InsertNextDNodeCycle(DLNode *p,DLNode *newnode){if(p==NULL||newnode==NULL){return false;}newnode->next=p->next;p->next->prior=newnode;newnode->prior=p;p->next=newnode;return true;
}//循环双向链表中删除已知结点p
bool DeleteDNodeCycle(DLNode *p){if(p==NULL){return false;}//这里删除的是头结点也同样适用,并没指明头结点在哪p->prior->next=p->next;if(p->next!=NULL){p->next->prior=p->prior;}return true;
}

http://www.lryc.cn/news/219588.html

相关文章:

  • [每周一更]-(第70期):常用的GIT操作命令
  • Leetcode-283 移动零
  • 爱上C语言:函数递归,青蛙跳台阶图文详解
  • Pycharm 对容器中的 Python 程序断点远程调试
  • 自动驾驶行业观察之2023上海车展-----车企发展趋势(3)
  • day55【动态规划子序列】392.判断子序列 115.不同的子序列
  • c语言中磁盘文件的分类
  • Unity适配微信
  • 虚拟机本地磁盘在线扩容
  • ACTIVE_MQ学习
  • 【C++初阶】类和对象(上)
  • 新版onenet平台安全鉴权的确定与使用
  • 容器核心技术-Namespace
  • linux写文件如何保证落盘?
  • 2023 electron最新最简版打包、自动升级详解
  • ConcurrentHashMap是如何实现线程安全的
  • MYSQL:索引与锁表范围简述
  • 15 款 PDF 编辑器帮助轻松编辑、合并PDF文档
  • PS Raw中文增效工具Camera Raw 16
  • Flink源码解析二之执行计划⽣成
  • MySQL遍历所有表所有字段查找字符数据
  • Java中的异常处理机制是怎样的?
  • 高教社杯数模竞赛特辑论文篇-2023年A题:定日镜场的优化设计(附获奖论文及MATLAB代码实现)
  • c语言实现http下载功能,显示进度条和下载速率
  • Educational Codeforces Round 157 (Rated for Div. 2) D. XOR Construction (思维题)
  • 【unity实战】实现类似英雄联盟的buff系统
  • 【C语言基础教程】函数指针与指针大小
  • Web前端—网页制作(以“学成在线”为例)
  • Hive【Hive(八)自定义函数】
  • linux远程桌面管理工具xrdp