C语言——栈的实现

栈---类似于实现制的线性表----只能从 一端经行插入删除

特点

  1. 后进先出(Last In First Out,LIFO):栈遵循后进先出的原则,即最后一个进入栈的元素将是第一个被移除的元素。
  2. 单端操作:栈只允许在栈顶进行插入和删除操作。这种操作通常被称为压栈(push)和弹栈(pop)。
  3. 受限的随机访问:栈中的元素只能通过栈顶访问,不能直接访问其他元素。
  4. 适用于简单的数据结构:栈只具有插入和删除元素的功能,不支持排序和查找等操作。
  5. 应用广泛:栈在计算机科学中有着广泛的应用,例如在函数调用、递归、深度优先搜索等领域。
cpp 复制代码
#include <stdio.h>
#include <stdbool.h>
#include <stdlib.h>

#define MAX_SIZE 100  // 定义栈的最大容量

typedef struct Stack {
    int data[MAX_SIZE];
    int top;  // 栈顶指针
} Stack;

// 初始化栈
void initStack(Stack* stack) {
    stack->top = -1;
}

// 判断栈是否为空
bool isEmpty(Stack* stack) {
    return stack->top == -1;
}

// 判断栈是否已满
bool isFull(Stack* stack) {
    return stack->top == MAX_SIZE - 1;
}

// 入栈操作
bool push(Stack* stack, int value) {
    if (isFull(stack)) {
        printf("栈已满,无法入栈。\n");
        return false;
    }
    stack->data[++stack->top] = value;
    return true;
}

// 出栈操作
bool pop(Stack* stack, int* value) {
    if (isEmpty(stack)) {
        printf("栈为空,无法出栈。\n");
        return false;
    }
    *value = stack->data[stack->top--];
    return true;
}

// 获取栈顶元素
bool getTop(Stack* stack, int* value) {
    if (isEmpty(stack)) {
        printf("栈为空。\n");
        return false;
    }
    *value = stack->data[stack->top];
    return true;
}

int main() {
    Stack stack;
    initStack(&stack);

    push(&stack, 1);
    push(&stack, 2);
    push(&stack, 3);

    int topValue;
    getTop(&stack, &topValue);
    printf("栈顶元素:%d\n", topValue);

    int popValue;
    pop(&stack, &popValue);
    printf("出栈元素:%d\n", popValue);

    return 0;
}
相关推荐
爱敲代码的TOM17 小时前
数据结构总结
数据结构
VekiSon17 小时前
Linux内核驱动——杂项设备驱动与内核模块编译
linux·c语言·arm开发·嵌入式硬件
2的n次方_18 小时前
CANN Ascend C 编程语言深度解析:异构并行架构、显式存储层级与指令级精细化控制机制
c语言·开发语言·架构
_F_y18 小时前
C语言重点知识总结(含KMP详细讲解)
c语言·开发语言
皮皮哎哟18 小时前
数据结构:嵌入式常用排序与查找算法精讲
数据结构·算法·排序算法·二分查找·快速排序
郝学胜-神的一滴19 小时前
深入解析C/S模型下的TCP通信流程:从握手到挥手的技术之旅
linux·服务器·c语言·网络·网络协议·tcp/ip
堕27419 小时前
java数据结构当中的《排序》(一 )
java·数据结构·排序算法
2302_8138062219 小时前
【嵌入式修炼:数据结构篇】——数据结构总结
数据结构
Wei&Yan20 小时前
数据结构——顺序表(静/动态代码实现)
数据结构·c++·算法·visual studio code
island131420 小时前
CANN GE(图引擎)深度解析:计算图优化管线、内存静态规划与异构 Stream 调度机制
c语言·开发语言·神经网络