链表中LinkList L与LinkList *L( & * L.elem L->elem)

摘要

LinkList L:L是结构体指针,使用"->"运算符来访问结构体成员;(*L)是结构体,使用"."运算符访问结构体成员

函数是否有&看是否要返回该链表等,若返回加&,否则不加;与L->elem还是L.elem没有关系

取地址符运算符&

取其操作对象的地址

指针运算符*

1.定义变量时,表示将x定义为指针类型变量

int *p:一级指针,表示p所指向地址里存放的是一个int类型的值

int **p:二级指针,表示p所指向地址里存放的是一个指向int类型的指针

2.运算时,其后跟指针表示指针所指变量的值

注意:用于运算时,*后不能跟未初始化的指针(定义时只分配存储指针本身的内存,未分配存储数据的内存)

结构体指针

typedef指Lnode替代struct Lnode,*LinkList替代struct LinkList*(结构体指针,指向整个结构体)

cs 复制代码
typedef struct Lnode{
	ElemType data;
	struct Lnode *next;
}Lnode,*LinkList;//LinkList为指向结构体Lnode的指针

对应的定义链表与结点指针也有两种方式。但L表示整个链表,所以常用LinkList定义;p表示指针,所以常用Lnode定义

cs 复制代码
//定义链表L
LinkList L;
Lnode *L;
//定义结点指针p
LinkList p;
Lnode *p;

L.elem和L->elem

L.elem:通过结构体变量L来访问结构体成员变量elem

L->elem:通过指针变量L指向的结构体成员变量elem,指针通过"->"可直接访问结构体中的成员,不需临时对象

区别:L.elem直接 访问结构体成员,L->elem通过指针访问结构体成员(适用于结构体变量被封装在指针中,通常动态内存分配中使用)

使用L.elem还是L->elem看结构体定义时,定义的为结构体Lnode(L->elem),还是结构体指针(L.elem)*LinkList。

main函数中pop(&s/s,e)?

看pop函数定义,sqstack *s对应&s; sqstack s对应s

相关推荐
earthzhang20213 小时前
【1007】计算(a+b)×c的值
c语言·开发语言·数据结构·算法·青少年编程
冷徹 .7 小时前
2024ICPC区域赛香港站
数据结构·c++·算法
韧竹、8 小时前
数据结构之顺序表
c语言·数据结构
努力努力再努力wz12 小时前
【C++进阶系列】:万字详解智能指针(附模拟实现的源码)
java·linux·c语言·开发语言·数据结构·c++·python
敲代码的嘎仔13 小时前
JavaWeb零基础学习Day2——JS & Vue
java·开发语言·前端·javascript·数据结构·学习·算法
yacolex13 小时前
3.3_数据结构和算法复习-栈
数据结构·算法
cookqq14 小时前
MongoDB源码delete分析oplog:从删除链路到核心函数实现
数据结构·数据库·sql·mongodb·nosql
ʚ希希ɞ ྀ15 小时前
用队列实现栈---超全详细解
java·开发语言·数据结构
要一起看日出15 小时前
数据结构-----栈&队列
java·数据结构··队列
Gorgous—l15 小时前
数据结构算法学习:LeetCode热题100-矩阵篇(矩阵置零、螺旋矩阵、旋转图像、搜索二维矩阵 II)
数据结构·学习·算法