在结点类型为DLink Node 的双链表中将p所指结点(非尾结点)与其后继结点交换的操作

2023-11-08 13:40

本文主要是介绍在结点类型为DLink Node 的双链表中将p所指结点(非尾结点)与其后继结点交换的操作,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在结点类型为DLink Node 的双链表中将p所指结点(非尾结点)与其后继结点交换的操作

C语言题解

#include <stdio.h>
#include <stdlib.h>
#include <stdbool.h>typedef struct Node{int data;struct Node *next,*prior;
}DNode,*DLinkList;void InitList(DLinkList L){L = (DLinkList)malloc(sizeof(DNode));L->next = NULL;L->prior = NULL;
}void InsertListByHead(DLinkList L,int x){DLinkList s = (DLinkList)malloc(sizeof(DNode));s->data = x;s->next = L->next;if(L->next!=NULL){L->next->prior = s;s->prior = L;L->next = s;}else{s->prior = L;L->next = s;}
}void ChangeNode(DLinkList p){DLinkList q = p->next;if(q->next==NULL){p->next = q->next;p->prior->next = q;q->prior = p->prior;p->prior = q;q->next = p;}else{p->next = q->next;p->prior->next = q;q->prior = p->prior;p->prior = q;q->next->prior = p;q->next = p;}
}void PrintList(DLinkList L){DLinkList p = L->next;while(p){printf("%d ",p->data);p = p->next;}
}int main(){DLinkList L;InitList(L);for(int i=10;i>0;i--){InsertListByHead(L,i);}printf("当前链表为:");PrintList(L);printf("\n进行交换结点后:\n");DLinkList p = L->next->next;ChangeNode(p);PrintList(L);return 0;
}

测试

一般情况
在这里插入图片描述

倒数第二个结点
在这里插入图片描述

这篇关于在结点类型为DLink Node 的双链表中将p所指结点(非尾结点)与其后继结点交换的操作的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/370236

相关文章

Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单

《Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单》:本文主要介绍Springboot的ThreadPoolTaskScheduler线... 目录ThreadPoolTaskScheduler线程池实现15分钟不操作自动取消订单概要1,创建订单后

SpringBoot操作spark处理hdfs文件的操作方法

《SpringBoot操作spark处理hdfs文件的操作方法》本文介绍了如何使用SpringBoot操作Spark处理HDFS文件,包括导入依赖、配置Spark信息、编写Controller和Ser... 目录SpringBoot操作spark处理hdfs文件1、导入依赖2、配置spark信息3、cont

Mysql 中的多表连接和连接类型详解

《Mysql中的多表连接和连接类型详解》这篇文章详细介绍了MySQL中的多表连接及其各种类型,包括内连接、左连接、右连接、全外连接、自连接和交叉连接,通过这些连接方式,可以将分散在不同表中的相关数据... 目录什么是多表连接?1. 内连接(INNER JOIN)2. 左连接(LEFT JOIN 或 LEFT

Node.js 中 http 模块的深度剖析与实战应用小结

《Node.js中http模块的深度剖析与实战应用小结》本文详细介绍了Node.js中的http模块,从创建HTTP服务器、处理请求与响应,到获取请求参数,每个环节都通过代码示例进行解析,旨在帮... 目录Node.js 中 http 模块的深度剖析与实战应用一、引言二、创建 HTTP 服务器:基石搭建(一

使用JavaScript操作本地存储

《使用JavaScript操作本地存储》这篇文章主要为大家详细介绍了JavaScript中操作本地存储的相关知识,文中的示例代码讲解详细,具有一定的借鉴价值,有需要的小伙伴可以参考一下... 目录本地存储:localStorage 和 sessionStorage基本使用方法1. localStorage

使用JavaScript将PDF页面中的标注扁平化的操作指南

《使用JavaScript将PDF页面中的标注扁平化的操作指南》扁平化(flatten)操作可以将标注作为矢量图形包含在PDF页面的内容中,使其不可编辑,DynamsoftDocumentViewer... 目录使用Dynamsoft Document Viewer打开一个PDF文件并启用标注添加功能扁平化

JavaScript DOM操作与事件处理方法

《JavaScriptDOM操作与事件处理方法》本文通过一系列代码片段,详细介绍了如何使用JavaScript进行DOM操作、事件处理、属性操作、内容操作、尺寸和位置获取,以及实现简单的动画效果,涵... 目录前言1. 类名操作代码片段代码解析2. 属性操作代码片段代码解析3. 内容操作代码片段代码解析4.

Redis的Hash类型及相关命令小结

《Redis的Hash类型及相关命令小结》edisHash是一种数据结构,用于存储字段和值的映射关系,本文就来介绍一下Redis的Hash类型及相关命令小结,具有一定的参考价值,感兴趣的可以了解一下... 目录HSETHGETHEXISTSHDELHKEYSHVALSHGETALLHMGETHLENHSET

SpringBoot使用Apache POI库读取Excel文件的操作详解

《SpringBoot使用ApachePOI库读取Excel文件的操作详解》在日常开发中,我们经常需要处理Excel文件中的数据,无论是从数据库导入数据、处理数据报表,还是批量生成数据,都可能会遇到... 目录项目背景依赖导入读取Excel模板的实现代码实现代码解析ExcelDemoInfoDTO 数据传输

Python使用asyncio实现异步操作的示例

《Python使用asyncio实现异步操作的示例》本文主要介绍了Python使用asyncio实现异步操作的示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋... 目录1. 基础概念2. 实现异步 I/O 的步骤2.1 定义异步函数2.2 使用 await 等待异