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;
}
相关推荐
移幻漂流9 分钟前
C/C++并发编程详解:如何写出优秀的并发程序
c语言·开发语言·c++
Jia shuheng1 小时前
#ifdef __cplusplus extern “C“ #endif的作用
c语言·嵌入式硬件
2401_841495641 小时前
【Python高级编程】单词统计与查找分析工具
数据结构·python·算法·gui·排序·单词统计·查找
进击的小头2 小时前
创建型模式:简单工厂模式(C语言实现)
c语言·开发语言·简单工厂模式
范纹杉想快点毕业2 小时前
嵌入式工程师一年制深度进阶学习计划(纯技术深耕版)
linux·运维·服务器·c语言·数据库·算法
-To be number.wan2 小时前
【数据结构真题解析】哈希表高级挑战:懒惰删除、探测链断裂与查找正确性陷阱
数据结构·算法·哈希算法
Qhumaing2 小时前
数据结构——例子求算法时间复杂度&&空间复杂度
数据结构·算法
鱼跃鹰飞2 小时前
Leetcode1027:最长等差数列
java·数据结构·算法
Stardep3 小时前
算法入门20——二分查找算法——搜索插入位置
数据结构·算法·leetcode
浅念-4 小时前
C语言——单链表
c语言·开发语言·数据结构·经验分享·笔记·算法·leetcode