关于如何理解链表结构体指针引用LinkNode * &L的问题

初学数据结构,在学习的过程中有了这个疑问,已经理解其中缘由,特写篇博客和大家一起分享交流。

C++中的引用:&


int a=10;
int &ra=a;

注意:此处&是标识符,不是取地址符!

a是目标原名称,ra是引用名,由引用的作用“引用就是某一变量(目标)的一个别名,对引用的操作与对变量直接操作完全一样。”可知当改变ra的值时,a的值也会随之改变。

此处主要讲的是引用的<传递可变参数>的作用,如一下代码

c形式:

void swapint(int *a,int *b)
{
int temp;
temp=*a;
*a=*b;
*b=temp;
}

c++形式:

void swapint(int &a,int &b)
{
int temp;
temp=a;
a=b;
b=temp;
}

以上两种代码作用相同,c++形式的代码采用了引用的方法,那么该函数结束后a,b的值也会随之改变,

int 是所引用变量的类型

链表结构体指针的引用


我所使用的教材是武汉大学的教学教材,其中结构体结点的定义如下:

typedef struct node{
  ElemType data;
  struct node *next;
}Linknode;

几个常见的链表操作的函数:

bool createlink(linknode * &L,elemtype a[],int n)//创建链表
bool delete(linknode * &L,int i)//删除第i个元素e

其他一些相关的语句:

linknode * L;//创建头结点
L=(linknode *)malloc(sizeof(linknode));//为头结点分配空间

linknode * L,即声明了一个结构体的指针,L指向的是这个结构体的首地址,记该地址为A1

malloc 为这个结构体指针类型的变量L分配的一个内存空间,此时即L指向的地址为A2

linknode * &L,即引用了这个结构体指针类型的变量L,引用L则会改变L,记delete函数执行完后L指向的地址为A3

我自己写了个简单的程序,输出这三个地址,发现:A1!=A2,  A2=A3

说明在删除一个元素之后L指向的地址并没有发生改变

我试着去掉insert函数用对L的引用符,发现依旧可以正常的删除,那么就没必要用引用符

结论


后来在询问了老师之后,我最终得到了如下结论:

引用L是为了改变L的值,而L指向的是链表的头结点的地址,即要改变头结点的地址,但是一般改链都是对头结点之后的结点进行操作,所以头结点的地址一直没变,故去掉&后函数依旧可以正常执行。之所以会加&,是以防有的链表没有头结点,因为可能会对第一个结点操作,那L的地址就会改变。

全部评论

相关推荐

刚刷到字节跳动官方发的消息,确实被这波阵仗吓了一跳。在大家还在纠结今年行情是不是又“寒冬”的时候,字节直接甩出了史上规模最大的转正实习计划——ByteIntern。咱们直接看几个最硬的数,别被花里胡哨的宣传词绕晕了。首先是“量大”。全球招7000多人是什么概念?这几乎是把很多中型互联网公司的总人数都给招进来了。最关键的是,这次的资源分配非常精准:研发岗给了4800多个Offer,占比直接超过六成。说白了,字节今年还是要死磕技术,尤其是产品和AI领域,这对于咱们写代码的同学来说,绝对是今年最厚的一块肥肉。其次是大家最关心的“转正率”。官方直接白纸黑字写了:整体转正率超过50%。这意味着只要你进去了,不划水、正常干,每两个人里就有一个能直接拿校招Offer。对于2027届(2026年9月到2027年8月毕业)的同学来说,这不仅是实习,这简直就是通往大厂的快捷通道。不过,我也得泼盆冷水。坑位多,不代表门槛低。字节的实习面试出了名的爱考算法和工程实操,尤其是今年重点倾斜AI方向,如果你简历里有和AI相关的项目,优势还是有的。而且,转正率50%也意味着剩下那50%的人是陪跑的,进去之后的考核压力肯定不小。一句话总结:&nbsp;27届的兄弟们,别犹豫了。今年字节这是铁了心要抢提前批的人才,现在投递就是占坑。与其等到明年秋招去千军万马挤独木桥,不如现在进去先占个工位,把转正名额攥在手里。
喵_coding:别逗了 50%转正率 仔细想想 就是转正与不转正
字节7000实习来了,你...
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务