iis服务器助手广告
返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >C语言如何复制复杂链表
  • 725
分享到

C语言如何复制复杂链表

2023-06-16 20:06:24 725人浏览 薄情痞子
摘要

这篇文章主要讲解了“C语言如何复制复杂链表”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C语言如何复制复杂链表”吧!什么是复杂链表?复杂链表指的是一个链表有若干个结点,每个结点有一个数据域用

这篇文章主要讲解了“C语言如何复制复杂链表”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C语言如何复制复杂链表”吧!

什么是复杂链表?

复杂链表指的是一个链表有若干个结点,每个结点有一个数据域用于存放数据,还有两个指针域,其中一个指向下一个节点,还有一个随机指向当前复杂链表中的任意一个节点或者是一个空结点。今天我们要实现的就是对这样一个复杂链表复制产生一个新的复杂链表。

复杂链表的数据结构如下:

typedef int DataType; //数据域的类型//复杂链表的数据结构typedef struct Complexnode{DataType _data ;   // 数据struct ComplexNode * _next;  // 指向下个节点的指针struct ComplexNode * _random; // 指向随机节点(可以是链表中的任意节点 or 空)}ComplexNode;

C语言如何复制复杂链表

上图就是一个复杂链表的例子,那么我们应该如何实现复杂链表的复制呢?

1、首先我们应该根据已有的复杂链表创建一条新的复杂链表,但是这个新的复杂链表的所有的结点的random指针都指向空,这样是很好实现的,相当于我们创建了一条简单的单链表(newlist),我们要复制的链表不妨称之为oldlist。

2、接下来我们应该把新创建的这条复杂链表(newlist)与已有的复杂链表(oldlist)合并成如下的形式:

C语言如何复制复杂链表

在这种情况下我们已经把两条复杂链表合并成了一条链表(称之为linklist),通过对这条链表(linklist)的观察,我们可以发现合并的链表(linklist)中属于newlist的结点pnew的上一个结点pold(属于oldlist的结点)的random指针所指向的结点的next指针就应该是pnew结点的randow指针所指向的结点。

这样我们让pold和pnew指针一直往后走最后就可以实现对所有属于新创建的复杂链表(newlist)的random指针指向相应的结点的操作。构成的复杂链表如下图

C语言如何复制复杂链表

在完成以上的步骤之后我们所要做的工作就很简单了,我们只要把这一条链表linklist分开成我们的newlist链表和oldlist链表就可以了。

这样我们就完美的完成了复杂链表的复制工作下面就是具体实现的代码:

头文件complexnode.h:

#ifndef __COMPLEX__NODE__H__#define __COMPLEX__NODE__H__//包含头文件#include <stdio.h>#include<stdlib.h>#include <assert.h>typedef int DataType; //数据域的类型//复杂链表的数据结构typedef struct ComplexNode{DataType _data ;    // 数据struct ComplexNode * _next;  // 指向下个节点的指针struct ComplexNode * _random; // 指向随机节点(可以是链表中的任意节点 or 空)}ComplexNode; //创建一个复杂链表的结点ComplexNode * BuyComplexNode(DataType x);//打印复杂的单链表void Display(const ComplexNode * cplist);//复杂链表的复制ComplexNode * CopyComplexNode(ComplexNode * cplist); #endif//__COMPLEX__NODE__H__

具体功能实现complexnode.c

#include "complexnode.h" //创建一个复杂链表的结点ComplexNode * BuyComplexNode(DataType x){ComplexNode *cnode = (ComplexNode *)malloc(sizeof(ComplexNode));if(cnode == NULL)//创建失败{perror("BuyComplexNode()::malloc");return NULL;}//创建成功cnode->_data = x;cnode->_next = NULL;cnode->_random = NULL;return cnode;} //打印复杂的单链表void Display(const ComplexNode * cplist){ComplexNode *pnode = cplist;while (pnode){printf("%d::%d -->",pnode->_data,pnode->_random->_data);pnode = pnode->_next;}printf("over\n");}//复杂链表的复制ComplexNode * CopyComplexNode(ComplexNode * cplist){ComplexNode * pold = NULL;ComplexNode * pnew = NULL;ComplexNode * newlist = NULL;//指向新的复杂链表的头结点的指针pold = cplist;//创建一条新的复杂链表while(pold != NULL){ComplexNode * new_node = BuyComplexNode(pold->_data);if(newlist == NULL)//当新的复杂链表中没有结点时{newlist = new_node;}else//当新的复杂链表有结点时{ComplexNode * node = newlist;while(node->_next != NULL)//找到最后一个结点{node = node->_next;}node->_next = new_node;//插入新的结点}pold = pold->_next; }//创建新的复杂链表结束 //合并两条复杂链表pold = cplist;pnew = newlist;while (pold){ComplexNode * curold = NULL;ComplexNode * curnew = NULL;curold = pold->_next;curnew = pnew->_next;if(pold->_next == NULL){pold->_next = pnew;pold = curold;pnew = curnew;break;}pold->_next = pnew;pnew->_next = curold;pold = curold;pnew = curnew;}//合并两条复杂链表结束 //让新创建的那条复杂链表上的所有结点的random指针指向相应的结点pold = cplist;pnew = newlist;while (pnew){pnew->_random = pold->_random->_next;pold = pnew->_next;if(pold == NULL)//这是pnew的_next指针已经指向空{break;}pnew = pold->_next;}//结束 //分离合并后的复杂链表pold = cplist;pnew = newlist;while (pold){ComplexNode * curold = NULL;ComplexNode * curnew = NULL;if(pnew->_next == NULL)//已经分离完成{pold->_next = NULL;pnew->_next = NULL;break; }curold = pold->_next->_next;curnew = pnew->_next->_next; pold->_next = curold;pnew->_next = curnew;pold = curold;pnew = curnew;}//分离合并的复杂链表结束 return newlist;}测试代码test.c:#include "complexnode.h"////复杂链表的复制。?个链表的每个节点,有?个指向next指针指向下?个节//点,还有?个random指针指向这个链表中的?个随机节点或者NULL,现在要//求实现复制这个链表,返回复制后的新链表。//ps: 复杂链表的结构 void test(){ComplexNode * cplist;ComplexNode * copylist;ComplexNode * node1;ComplexNode * node2;ComplexNode * node3;ComplexNode * node4;cplist = BuyComplexNode(1);node1 = BuyComplexNode(2);node2 = BuyComplexNode(3);node3 = BuyComplexNode(4);node4 = BuyComplexNode(5);cplist->_next = node1;node1->_next = node2;node2->_next = node3;node3->_next = node4;cplist->_random = node3;node1->_random = node4;node2->_random = cplist;node3->_random = node1;node4->_random = node2;Display(cplist);copylist = CopyComplexNode(cplist);Display(copylist);}int main(){test();return 0;}

程序的运行结果如下图:

C语言如何复制复杂链表

感谢各位的阅读,以上就是“C语言如何复制复杂链表”的内容了,经过本文的学习后,相信大家对C语言如何复制复杂链表这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

--结束END--

本文标题: C语言如何复制复杂链表

本文链接: https://www.lsjlt.com/news/285064.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • C语言如何复制复杂链表
    这篇文章主要讲解了“C语言如何复制复杂链表”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C语言如何复制复杂链表”吧!什么是复杂链表?复杂链表指的是一个链表有若干个结点,每个结点有一个数据域用...
    99+
    2023-06-16
  • C语言复杂链表的复制实例详解
    目录一、题目描述示例1:示例2:示例3:示例4:二、思路分析三、整体代码总结一、题目描述 请实现 copyRandomList 函数,复制一个复杂链表。在复杂链表中,每个节点除了有一...
    99+
    2024-04-02
  • Java复杂链表的复制详解
    目录1.题目2.解法2.1 拼接+拆分3.代码1.题目 请实现 copyRandomList 函数,复制一个复杂链表。在复杂链表中,每个节点除了有一个 next 指针指向下一个节点,...
    99+
    2024-04-02
  • C语言数据结构之复杂链表的拷贝
    题目: 给你一个长度为 n 的链表,每个节点包含一个额外增加的随机指针 random ,该指针可以指向链表中的任何节点或空节点。 构造这个链表的 深拷贝。 深拷贝应该正好由 n 个 ...
    99+
    2024-04-02
  • java算法题解LeetCode35复杂链表的复制实例
    目录题目示例 1:示例 2:示例 3:示例 4:解题思路题目 AC 剑指 Offer 35. 复杂链表的复制请实现 copyRandomList 函数,复制一个复杂链表。在复杂链表中...
    99+
    2023-01-05
    java算法复杂链表复制 java LeetCode
  • C语言算法的时间复杂度和空间复杂度
    目录1.算法效率1.1 如何衡量一个算法的好坏1.2算法的复杂度2.时间复杂度2.1 时间复杂度的概念2.2 大O的渐进表示法2.3常见时间复杂度计算举例 3.空间复杂度4...
    99+
    2024-04-02
  • c语言链表如何实现
    这篇“c语言链表如何实现”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“c语言链表如何实现”文章吧。在计算机领域离不开算法和数...
    99+
    2023-06-19
  • R语言ComplexHeatmap绘制复杂热图heatmap
    目录一 载入R包 数据1.1 载入ComplexHeatmap包,数据1.2 绘制最简单的热图二 常见“表型”注释2.1读入注释文件2.2添加注释,且设置颜色...
    99+
    2024-04-02
  • Java面试题-实现复杂链表的复制代码分享
    阿里终面在线编程题,写出来与大家分享一下        有一个单向链表,每个节点都包含一个random指针,指向本链表中的某个节点或者为空,写一个深度拷贝函数,拷贝整个链...
    99+
    2023-05-31
    java 链表 ava
  • C语言时间复杂度和空间复杂度实例分析
    今天小编给大家分享一下C语言时间复杂度和空间复杂度实例分析的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。1.时间复杂度:首先...
    99+
    2023-06-30
  • C语言如何实现文件复制
    本篇内容主要讲解“C语言如何实现文件复制”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“C语言如何实现文件复制”吧!C语言文件复制实例详解文件复制,在Linux中,将生成的read.o 重新文件拷...
    99+
    2023-06-16
  • C语言详细解析时间复杂度与空间复杂度
    目录一、概念1.1、算法效率1.2、时间复杂度1.3、空间复杂度二、计算2.1、大O的渐进表示法2.2、时间复杂度计算2.3、空间复杂度计算三、有复杂度要求的习题一、概念 1.1、算...
    99+
    2024-04-02
  • C语言时间复杂度与空间复杂度实例分析
    这篇文章主要介绍“C语言时间复杂度与空间复杂度实例分析”,在日常操作中,相信很多人在C语言时间复杂度与空间复杂度实例分析问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”C语言时间复杂度与空间复杂度实例分析”的疑...
    99+
    2023-06-29
  • C语言中如何使用链表
    这篇文章主要介绍C语言中如何使用链表,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!一、结构体的概念比如说学生的信息,包含了学生名称、学号、性别、年龄等信息,这些参数可能有些是数组型、字符型、整型、甚至是结构体类型的数...
    99+
    2023-06-29
  • c语言单链表如何创建
    创建单链表的基本思路如下:1. 定义一个结构体用来表示链表中的节点,结构体中包含一个数据域用来存储节点的值,还包含一个指针域用来指向...
    99+
    2023-08-25
    c语言
  • c语言如何实现字符串复制
    在C语言中,可以使用strcpy()函数来实现字符串复制。具体实现方法如下: #include <stdio.h> #i...
    99+
    2024-04-09
    c语言
  • Java复杂链表的示例分析
    这篇文章将为大家详细讲解有关Java复杂链表的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。1.题目请实现 copyRandomList 函数,复制一个复杂链表。在复杂链表中,每个节点除了有一个 ...
    99+
    2023-06-28
  • C语言三分钟精通时间复杂度与空间复杂度
    目录一、时间复杂度1)O(n)的含义2)复杂表达式的简化3)O(n)不一定优于O(n^2)​4)递归的时间复杂度二、空间复杂度1)O(1)空间复杂度​2)​​​​​​​O(n)空间复...
    99+
    2024-04-02
  • C语言数据结构的时间复杂度和空间复杂度
    目录一、数据结构前言        1.什么是数据结构:        2.什么是...
    99+
    2023-05-15
    C语言时间复杂度和空间复杂度 C语言时间复杂度 C语言空间复杂度
  • C语言数据结构通关时间复杂度和空间复杂度
    目录一、时间复杂度:1.常数阶2.线性阶3.对数阶4.平方阶二、空间复杂度算法的时间复杂度和空间复杂度 一、时间复杂度: 首先,为什么会有这个概念的出现呢? 原来啊,在进行算法分析时...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作