关于p-next=p;和p=p-next;的刨根问底(也有转的内容)

2023-11-05 04:49
文章标签 内容 next 刨根问底

本文主要是介绍关于p-next=p;和p=p-next;的刨根问底(也有转的内容),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

qq群里面有个哥们问我这个问题,我是一个喜欢在事物的原理方面刨根问底的人。

帮他在网上找了一篇不错的回答,但是自己还想亲手编程证实。百度知道的地址:http://zhidao.baidu.com/link?url=O1UyyyHkTWs-KkUefQOzbwASO5n3q3BDZ5ToV4VAHryv4EBbdpVNJ88qD5NfqccMnX79zVt8mofXl01pnOVXnK(详细内容附后)


(I) 证实p=p->next;

#include<iostream>
#include<math.h>using namespace std;typedef struct node
{int data;struct node *next;
}NODE;int main(void)
{NODE a,b,c;NODE *p;a.data=1;a.next=&b;b.data=2;b.next=&c;c.data=3;c.next=&a;p=&a;while(p!=NULL){printf("%d\n",p->data);p=p->next;  //p->next放的是下一个的地址 eg.0x0018ff38}return 0;
}

直接贴出运行结果,我觉得就可以说明问题了,相当于p->next是一个指针,这个指针就要指向一个东西(就是下一个节点),但是这个指针里面放的是一个地址




(II) 证实p->next=p;

代码略改一行:

while(p!=NULL)
{printf("%d\n",p->data);p->next=p;
}



下面贴出网上回答内容:

p->next=p表示节点p的下一个节点还是p,如果链表只有p节点,那么这样就变成了一个循环链表
p=p->next表示修改指针p的位置,把p指向原来的下一个节点
追问
你的意思是p->next=p是修改结点位置,而p=p->next是修改指针位置?
回答
不是,假如链表为  p1-p2-p3-.......
p1->next=p1,那么链表就断了,p2,p3会找不到了,链表变成了
p1--|
|-----|   也就是它自己指向自己了
追问
p1->next=p1,那么链表就断了,p2,p3会找不到了
这个不是通过将指向p1的指针转到指向p2,使得p1消失?怎么会p2,p3找不到呢
回答
这里有一个连如下:
......->[0000]->[1111]->[2222]->[3333]->........|p         开始时p指向节点[0000],那么p->next指向的是节点[1111]
如果执行语句  p->next=p,实际上就是修改了指针p->next的位置,p没有变,链表变成了:
......->[0000]->||_____|p            这个样了,其它节点还在,但是不能遍历它们了,因为p->next 还是它自己本身,所以其它节点就找不到了
如果执行p=p->next,这样是修改了p位置,链表变成如下:
......->[0000]->[1111]->[2222]->[3333]->........|p
追问
昨晚办公室关没了,没来得及看哈
嗯嗯,终于理解了,不过我怎么觉得那p->next=p;没什么用了。。。
回答
那就要看特定情况下了,例如创建一个没有头结点的循环链表时,开始第一个节点就要这样了,如果不是第一个节点那就有 p->next=head; head表示第一个节点,p为最后一个节点
提问者评价
嗯,谢谢!这样随时在线的也不容易




这篇关于关于p-next=p;和p=p-next;的刨根问底(也有转的内容)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

如何解决Pycharm编辑内容时有光标的问题

《如何解决Pycharm编辑内容时有光标的问题》文章介绍了如何在PyCharm中配置VimEmulator插件,包括检查插件是否已安装、下载插件以及安装IdeaVim插件的步骤... 目录Pycharm编辑内容时有光标1.如果Vim Emulator前面有对勾2.www.chinasem.cn如果tools工

C#比较两个List集合内容是否相同的几种方法

《C#比较两个List集合内容是否相同的几种方法》本文详细介绍了在C#中比较两个List集合内容是否相同的方法,包括非自定义类和自定义类的元素比较,对于非自定义类,可以使用SequenceEqual、... 目录 一、非自定义类的元素比较1. 使用 SequenceEqual 方法(顺序和内容都相等)2.

你的华为手机升级了吗? 鸿蒙NEXT多连推5.0.123版本变化颇多

《你的华为手机升级了吗?鸿蒙NEXT多连推5.0.123版本变化颇多》现在的手机系统更新可不仅仅是修修补补那么简单了,华为手机的鸿蒙系统最近可是动作频频,给用户们带来了不少惊喜... 为了让用户的使用体验变得很好,华为手机不仅发布了一系列给力的新机,还在操作系统方面进行了疯狂的发力。尤其是近期,不仅鸿蒙O

两个月冲刺软考——访问位与修改位的题型(淘汰哪一页);内聚的类型;关于码制的知识点;地址映射的相关内容

1.访问位与修改位的题型(淘汰哪一页) 访问位:为1时表示在内存期间被访问过,为0时表示未被访问;修改位:为1时表示该页面自从被装入内存后被修改过,为0时表示未修改过。 置换页面时,最先置换访问位和修改位为00的,其次是01(没被访问但被修改过)的,之后是10(被访问了但没被修改过),最后是11。 2.内聚的类型 功能内聚:完成一个单一功能,各个部分协同工作,缺一不可。 顺序内聚:

STL经典案例(四)——实验室预约综合管理系统(项目涉及知识点很全面,内容有点多,耐心看完会有收获的!)

项目干货满满,内容有点过多,看起来可能会有点卡。系统提示读完超过俩小时,建议分多篇发布,我觉得分篇就不完整了,失去了这个项目的灵魂 一、需求分析 高校实验室预约管理系统包括三种不同身份:管理员、实验室教师、学生 管理员:给学生和实验室教师创建账号并分发 实验室教师:审核学生的预约申请 学生:申请使用实验室 高校实验室包括:超景深实验室(可容纳10人)、大数据实验室(可容纳20人)、物联网实验

【python计算机视觉编程——8.图像内容分类】

python计算机视觉编程——8.图像内容分类 8.图像内容分类8.1 K邻近分类法(KNN)8.1.1 一个简单的二维示例8.1.2 用稠密SIFT作为图像特征8.1.3 图像分类:手势识别 8.2贝叶斯分类器用PCA降维 8.3 支持向量机8.3.2 再论手势识别 8.4 光学字符识别8.4.2 选取特征8.4.3 多类支持向量机8.4.4 提取单元格并识别字符8.4.5 图像校正

JS中【记忆函数】内容详解与应用

在 JavaScript 中,记忆函数(Memoization)是一种优化技术,旨在通过存储函数的调用结果,避免重复计算以提高性能。它非常适用于纯函数(同样的输入总是产生同样的输出),特别是在需要大量重复计算的场景中。为了彻底理解 JavaScript 中的记忆函数,本文将从其原理、实现方式、应用场景及优化方法等多个方面详细讨论。 一、记忆函数的基本原理 记忆化是一种缓存策略,主要用于函数式编

【鸿蒙HarmonyOS NEXT】页面之间相互传递参数

【鸿蒙HarmonyOS NEXT】页面之间相互传递参数 一、环境说明二、页面之间相互传参 一、环境说明 DevEco Studio 版本: API版本:以12为主 二、页面之间相互传参 说明: 页面间的导航可以通过页面路由router模块来实现。页面路由模块根据页面url找到目标页面,从而实现跳转。通过页面路由模块,可以使用不同的url访问不同的页面,包括跳转到U