栈的C实现

栈的C实现

栈简介

栈(Stack)是一种后进先出的数据结构,类似于一个垂直的容器。

栈的特点是后进先出,即最后入栈的元素最先出栈。栈可以用来解决递归问题、实现函数调用、以及存储临时数据等。

例如,在计算机科学中,栈常用于实现函数调用栈,记录函数调用的顺序和参数。

希望本文通过使用C语言实现栈操作可以帮助读者理解栈的基本原理。

栈的C实现

1.栈结构体

想要实现栈结构,我们就要对其分配空间,可以使用结构体来实现。

结构体包含的此栈空间的起始地址、栈尺寸、栈顶元素。

如下:

C 复制代码
//栈结构体
typedef struct Stack {
    int *data;      // 栈内元素指针
    int top;        // 栈顶元素索引
    int size;       // 栈尺寸
} Stack;

2.初始化栈

有了栈结构后,我们在使用栈之前还要进行初始化。

初始化操作有分配一个栈结构体、分配指定大小的内存空间存储栈数据。

如下:

C 复制代码
// 初始化栈
Stack* initStack(int size) 
{
    Stack *stack = (Stack *)malloc(sizeof(Stack));      //  分配栈结构体并获取结构体指针
    stack->data = (int *)malloc(size * sizeof(int));    //  为栈内元素分配有size个int类型元素的空间,并将地址赋值给栈内元素指针
    stack->top = -1;                                     //  初始化栈顶元素索引为-1,表示栈空
    stack->size = size;                                  //  初始化栈尺寸为实际大小(即传入的size大小)
    return stack;                                       //  返回栈结构体指针
}

3.栈的基本操作

C 复制代码
// 入栈
void push(Stack *stack, int value)
{
    if (stack->top < stack->size - 1)       // 判断栈是否已满
    {
        stack->data[++stack->top] = value;  //将栈顶索引加1,并将数据插入栈顶
    }
    else 
    {
        printf("栈已满,无法入栈!\n");
    }
}

// 出栈
int pop(Stack *stack)
{
    if (stack->top >= 0)                     // 判断栈是否为空
    {
        return stack->data[stack->top--];   // 从栈顶获取数据,并将栈顶索引减1
    }
    else
    {
        printf("栈为空,无法出栈!\n");
        return -1; // 或者返回异常
    }
}

// 获取栈顶元素
int top(Stack *stack)
{
    if (stack->top >= 0)                     // 判断栈是否为空
    {
        return stack->data[stack->top];     // 从栈顶获取数据
    }
    else
    {
        printf("栈为空,无法获取栈顶元素!\n");
        return -1; // 或者返回异常
    }
}

// 将栈设置为空
int setEmpty(Stack *stack)
{
    return stack->top == -1;
}

// 释放栈资源
void freeStack(Stack *stack)
{
    free(stack->data);
    free(stack);
}

以上就是用C实现的栈的基本操作,

当然栈还有共享栈、链栈等,但本文介绍到的操作也是提到的这两种栈操作的基本,读者可以尝试着在此基础上实现共享栈与链栈的操作。

相关推荐
lingchen190621 分钟前
MATLAB的数值计算(三)曲线拟合与插值
开发语言·matlab
索迪迈科技35 分钟前
基于野火F407开发板实现电源管理-停止模式
c语言·stm32·单片机·嵌入式硬件·mcu
gb42152871 小时前
java中将租户ID包装为JSQLParser的StringValue表达式对象,JSQLParser指的是?
java·开发语言·python
一朵梨花压海棠go1 小时前
html+js实现表格本地筛选
开发语言·javascript·html·ecmascript
蒋星熠1 小时前
Flutter跨平台工程实践与原理透视:从渲染引擎到高质产物
开发语言·python·算法·flutter·设计模式·性能优化·硬件工程
小莞尔1 小时前
【51单片机】【protues仿真】基于51单片机宠物投食系统
c语言·stm32·单片机·嵌入式硬件·51单片机
翻滚丷大头鱼1 小时前
Java 集合Collection—List
java·开发语言
小欣加油1 小时前
leetcode 面试题01.02判定是否互为字符重排
数据结构·c++·算法·leetcode·职场和发展
3Cloudream1 小时前
LeetCode 003. 无重复字符的最长子串 - 滑动窗口与哈希表详解
算法·leetcode·字符串·双指针·滑动窗口·哈希表·中等
王璐WL2 小时前
【c++】c++第一课:命名空间
数据结构·c++·算法