在结点类型为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

相关文章

Python ZIP文件操作技巧详解

《PythonZIP文件操作技巧详解》在数据处理和系统开发中,ZIP文件操作是开发者必须掌握的核心技能,Python标准库提供的zipfile模块以简洁的API和跨平台特性,成为处理ZIP文件的首选... 目录一、ZIP文件操作基础三板斧1.1 创建压缩包1.2 解压操作1.3 文件遍历与信息获取二、进阶技

Java中字符串转时间与时间转字符串的操作详解

《Java中字符串转时间与时间转字符串的操作详解》Java的java.time包提供了强大的日期和时间处理功能,通过DateTimeFormatter可以轻松地在日期时间对象和字符串之间进行转换,下面... 目录一、字符串转时间(一)使用预定义格式(二)自定义格式二、时间转字符串(一)使用预定义格式(二)自

Java字符串操作技巧之语法、示例与应用场景分析

《Java字符串操作技巧之语法、示例与应用场景分析》在Java算法题和日常开发中,字符串处理是必备的核心技能,本文全面梳理Java中字符串的常用操作语法,结合代码示例、应用场景和避坑指南,可快速掌握字... 目录引言1. 基础操作1.1 创建字符串1.2 获取长度1.3 访问字符2. 字符串处理2.1 子字

Node.js 数据库 CRUD 项目示例详解(完美解决方案)

《Node.js数据库CRUD项目示例详解(完美解决方案)》:本文主要介绍Node.js数据库CRUD项目示例详解(完美解决方案),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考... 目录项目结构1. 初始化项目2. 配置数据库连接 (config/db.js)3. 创建模型 (models/

Python 中的 with open文件操作的最佳实践

《Python中的withopen文件操作的最佳实践》在Python中,withopen()提供了一个简洁而安全的方式来处理文件操作,它不仅能确保文件在操作完成后自动关闭,还能处理文件操作中的异... 目录什么是 with open()?为什么使用 with open()?使用 with open() 进行

使用Node.js制作图片上传服务的详细教程

《使用Node.js制作图片上传服务的详细教程》在现代Web应用开发中,图片上传是一项常见且重要的功能,借助Node.js强大的生态系统,我们可以轻松搭建高效的图片上传服务,本文将深入探讨如何使用No... 目录准备工作搭建 Express 服务器配置 multer 进行图片上传处理图片上传请求完整代码示例

MySQL 中查询 VARCHAR 类型 JSON 数据的问题记录

《MySQL中查询VARCHAR类型JSON数据的问题记录》在数据库设计中,有时我们会将JSON数据存储在VARCHAR或TEXT类型字段中,本文将详细介绍如何在MySQL中有效查询存储为V... 目录一、问题背景二、mysql jsON 函数2.1 常用 JSON 函数三、查询示例3.1 基本查询3.2

Linux ls命令操作详解

《Linuxls命令操作详解》通过ls命令,我们可以查看指定目录下的文件和子目录,并结合不同的选项获取详细的文件信息,如权限、大小、修改时间等,:本文主要介绍Linuxls命令详解,需要的朋友可... 目录1. 命令简介2. 命令的基本语法和用法2.1 语法格式2.2 使用示例2.2.1 列出当前目录下的文

Pydantic中Optional 和Union类型的使用

《Pydantic中Optional和Union类型的使用》本文主要介绍了Pydantic中Optional和Union类型的使用,这两者在处理可选字段和多类型字段时尤为重要,文中通过示例代码介绍的... 目录简介Optional 类型Union 类型Optional 和 Union 的组合总结简介Pyd

Oracle数据库常见字段类型大全以及超详细解析

《Oracle数据库常见字段类型大全以及超详细解析》在Oracle数据库中查询特定表的字段个数通常需要使用SQL语句来完成,:本文主要介绍Oracle数据库常见字段类型大全以及超详细解析,文中通过... 目录前言一、字符类型(Character)1、CHAR:定长字符数据类型2、VARCHAR2:变长字符数