当前位置:首页C语言 > 正文

C语言中关于堆栈的基础操作

作者:野牛程序员:2024-11-18 14:22:40C语言阅读 2302
C语言中关于堆栈的基础操作

C语言中关于堆栈的基础操作

在 C 语言中,堆栈是一种 后进先出(LIFO,Last In First Out) 的数据结构。堆栈的基础操作包括初始化入栈(Push)出栈(Pop)查看栈顶元素(Peek/Top)检查是否为空(IsEmpty) 等。以下是 C 语言实现堆栈的基础操作:


代码实现

1. 定义堆栈结构

#include <stdio.h>
#include <stdlib.h>

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

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

2. 初始化堆栈

void initStack(Stack* stack) {
    stack->top = -1;  // 初始化栈顶指针为 -1,表示栈为空
}

3. 检查栈是否为空

int isEmpty(Stack* stack) {
    return stack->top == -1;  // 栈顶指针为 -1 时,栈为空
}

4. 检查栈是否已满

int isFull(Stack* stack) {
    return stack->top == MAX_SIZE - 1;  // 栈顶指针达到最大容量时,栈已满
}

5. 入栈操作(Push)

void push(Stack* stack, int value) {
    if (isFull(stack)) {
        printf("栈已满,无法插入元素 %d\n", value);
        return;
    }
    stack->data[++stack->top] = value;  // 栈顶指针先加1,再插入元素
}

6. 出栈操作(Pop)

int pop(Stack* stack) {
    if (isEmpty(stack)) {
        printf("栈为空,无法进行出栈操作\n");
        return -1;  // 返回 -1 表示出栈失败
    }
    return stack->data[stack->top--];  // 返回栈顶元素,并将栈顶指针减1
}

7. 查看栈顶元素(Peek/Top)

int peek(Stack* stack) {
    if (isEmpty(stack)) {
        printf("栈为空,无法查看栈顶元素\n");
        return -1;  // 返回 -1 表示栈顶元素不存在
    }
    return stack->data[stack->top];  // 返回栈顶元素
}

完整示例:测试堆栈操作

int main() {
    Stack stack;       // 定义一个栈
    initStack(&stack); // 初始化栈

    // 入栈操作
    push(&stack, 10);
    push(&stack, 20);
    push(&stack, 30);

    printf("栈顶元素: %d\n", peek(&stack)); // 查看栈顶元素

    // 出栈操作
    printf("出栈元素: %d\n", pop(&stack));
    printf("出栈元素: %d\n", pop(&stack));

    // 检查栈是否为空
    if (isEmpty(&stack)) {
        printf("栈已空\n");
    } else {
        printf("栈未空,栈顶元素: %d\n", peek(&stack));
    }

    return 0;
}
  • Stack 结构体

    • 包含数组 data 存储栈元素,top 表示栈顶指针。

  • 初始化操作

    • 将栈顶指针初始化为 -1 表示栈为空。

  • 入栈和出栈

    • 入栈操作检查栈是否已满,出栈操作检查栈是否为空。

  • 动态数组栈

    • 如果需要支持动态大小的栈,可用 malloc 动态分配内存替代固定大小的数组。


野牛程序员教少儿编程与信息学奥赛-微信|电话:15892516892
野牛程序员教少儿编程与信息学竞赛-微信|电话:15892516892
  • C语言中关于堆栈的基础操作
  • 相关推荐

    最新推荐

    热门点击