二级指针的用法

本文介绍了二级指针的概念,并通过一个例子展示了如何使用二级指针实现链栈和链队列。在被调函数中,若需修改一级指针的值,如链表或二叉树操作时改变头结点或根节点,二级指针是必要的。同时,文章还简单总结了指针的数据类型。
摘要由CSDN通过智能技术生成

1、二级指针(指向指针的指针)

那么二级指针有什么用呢?看一个用二级指针实现的链栈和链队列的例子

源代码中各个文件说明:
stack_queue.h文件中存放结点的定义以及函数的声明
stack.c文件中存放栈的实现
queue.c文件中中存放队列的实现

stack_queue.h文件:

 

#ifndef STACK_QUEUE_H
#define STACK_QUEUE_H

#include<stdlib.h>

#define ERROR -10000

typedef int NodeType;//令结点类型为int型

//栈、队列中结点的定义
typedef struct node
{
	NodeType data;
	struct node * next;
}Node,*PNode;


//链栈用带头结点的单链表实现

void init_stack(PNode* top);//初始化栈
NodeType pop(PNode* top);//弹栈
NodeType pep(PNode top);//取栈顶元素
void push(PNode* top,NodeType data);//压栈
int stack_empty(PNode top);//判断栈是否为空


//链队列用带头结点的循环单链表实现

void init_queue(PNode* rear);//初始化队列
NodeType de_queue(PN
  • 0
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值