快速入门数据结构--栈

一、栈

一、什么是栈?

栈(Stack) 是一种只能在一端进行插入和删除操作的线性数据结构。这一端被称为栈顶(Top) ,另一端固定不动,称为栈底(Bottom)

这里大家把它认为是一个水桶就行,记住一个特点:后进先出

二、栈的基本操作

操作 作用
push() 将一个元素压入栈顶
pop() 将栈顶元素弹出并返回
peek()top() 查看栈顶元素但不移除它
isEmpty() 判断栈是否为空
isFull() 判断栈是否已满(适用于数组实现)
size() 返回栈中元素的数量

三、栈的实现方式

  1. 使用数组实现(静态栈)

定义结构体,顺序表这部分都懂

cs 复制代码
#define MAX_SIZE 100 // 最大容量

typedef struct {
    int arr[MAX_SIZE]; // 存储栈的数组
    int top;           // 栈顶指针(初始为 -1)
} Stack;

初始化栈

cs 复制代码
void initStack(Stack *s) {
    s->top = -1;//因为数组默认下标是0,空栈的下标设置为-1
}

压栈 push

cs 复制代码
void push(Stack *s, int value) {
    if (!isFull(s)) {
        s->arr[++(s->top)] = value;//栈顶指针向上移动
    } else {
        printf("Stack overflow\n");
    }
}

弹栈 pop

cs 复制代码
int pop(Stack *s) {
    if (!isEmpty(s)) {
        return s->arr[(s->top)--];//根压栈相反,取出来那栈顶指针就下移
    } else {
        printf("Stack underflow\n");
        return -1;
    }
}

查看栈顶 peek

cs 复制代码
int peek(Stack *s) {
    if (!isEmpty(s)) {
        return s->arr[s->top];
    } else {
        printf("Stack is empty\n");
        return -1;
    }
}

2. 使用链表实现(动态栈)

把它当成单链表就行,只不过多了个指向最后一个节点的top指针

代码演示一下吧 :

定义节点结构

cs 复制代码
typedef struct Node {
    int data;
    struct Node* next;
} Node;

定义栈结构

cs 复制代码
typedef struct {
    Node* top; // 栈顶指针
} Stack;

初始化栈

cs 复制代码
void initStack(Stack *s) {
    s->top = NULL;
}

判断栈空

cs 复制代码
int isEmpty(Stack *s) {
    return s->top == NULL;
}

压栈 push

cs 复制代码
void push(Stack *s, int value) {
    Node* newNode = (Node*)malloc(sizeof(Node));
    if (newNode == NULL) {
        printf("Memory allocation failed\n");
        return;
    }

    newNode->data = value;
    newNode->next = s->top;
    s->top = newNode;
}

弹栈 pop

cs 复制代码
int pop(Stack *s) {
    if (!isEmpty(s)) {
        Node* temp = s->top;
        int value = temp->data;
        s->top = s->top->next;
        free(temp);
        return value;
    } else {
        printf("Stack underflow\n");
        return -1;
    }
}

查看栈顶 peek

cs 复制代码
int peek(Stack *s) {
    if (!isEmpty(s)) {
        return s->top->data;
    } else {
        printf("Stack is empty\n");
        return -1;
    }
}

下期明天更,睡觉了宝子们!

相关推荐
CoovallyAIHub15 小时前
Moonshine:比 Whisper 快 100 倍的端侧语音识别神器,Star 6.6K!
深度学习·算法·计算机视觉
CoovallyAIHub16 小时前
速度暴涨10倍、成本暴降6倍!Mercury 2用扩散取代自回归,重新定义LLM推理速度
深度学习·算法·计算机视觉
CoovallyAIHub16 小时前
实时视觉AI智能体框架来了!Vision Agents 狂揽7K Star,延迟低至30ms,YOLO+Gemini实时联动!
算法·架构·github
CoovallyAIHub16 小时前
开源:YOLO最强对手?D-FINE目标检测与实例分割框架深度解析
人工智能·算法·github
CoovallyAIHub17 小时前
OpenClaw:从“19万星标”到“行业封杀”,这只“赛博龙虾”究竟触动了谁的神经?
算法·架构·github
刀法如飞17 小时前
程序员必须知道的核心算法思想
算法·编程开发·算法思想
徐小夕18 小时前
pxcharts Ultra V2.3更新:多维表一键导出 PDF,渲染兼容性拉满!
vue.js·算法·github
CoovallyAIHub19 小时前
OpenClaw一脚踩碎传统CV?机器终于不再只是看世界
深度学习·算法·计算机视觉
CoovallyAIHub19 小时前
仅凭单目相机实现3D锥桶定位?UNet-RKNet破解自动驾驶锥桶检测难题
深度学习·算法·计算机视觉