利用c语言详细介绍下栈的实现

news2025/1/12 21:50:26

    数据结构中,栈是一种线性结构,数据元素遵循后进先出的原则。栈的一端为栈顶,一端为栈底或栈尾,数据只在栈顶端进行操作。新插入数据称为入栈或者压栈,删除数据叫做出栈或者退栈。

一、图文介绍

    我们通过建立一个stack的数据结构进行栈的声明,栈的操作通过具体函数实现。stacksize代表栈的总大小,base指针指向栈底,top指针指向栈顶。

1.1,栈的初始化

    我们初始化栈大小为30,也就是说最大存储元素为30个。

1.2,压栈

    我们依次压入数据3,5,9,1,7五个元素,top指针随着数据压入二变动:

 

1.3,出栈

    我们依次出栈7,1,5三个元素,top指针随着数据出栈而变动,栈内部的数据实际未动,后期压栈会覆盖。

 

二、代码实现

2.1,声明

    我们定义要给t_stack.h头文件,内部进行结构体和方法声明:

 

#ifndef TEST1_T_STACK_H
#define TEST1_T_STACK_H


#define STACK_INIT_SIZE 30
#define STACK_INCREMENT 10


typedef  int status;

typedef struct Stack{
    int *base;
    int *top;
    int stacksize;
}stack;


status initStack(stack *);

status destroyStack(stack *);

status clearStack(stack *);

status stackIsEmpty(stack *);

int stackLength(stack *);

status getTop(stack *,int *);

status push(stack *,int data);

status pop(stack *);

void testStack();



#endif //TEST1_T_STACK_H

2.2,初始化函数

status initStack(stack *sqStack)
{

    sqStack->base = (int *)malloc(STACK_INIT_SIZE*sizeof(int));

    if(!sqStack->base)
    {
        printf("stack init failed!\n");
        exit(0);
    }
    sqStack->top = sqStack->base;
    sqStack->stacksize = STACK_INIT_SIZE;
    return OK;

}

2.3,压栈函数

status push(stack *sqStack, int data)
{
    if(sqStack->top-sqStack->base>=sqStack->stacksize)
    {
        sqStack->base = (int *)realloc(sqStack->base,(sqStack->stacksize+STACK_INCREMENT)*sizeof(int));
        if(!sqStack->base)
        {
            printf("stack reallocate failed!\n");
            exit(0);
        }
        sqStack->top = sqStack->base+sqStack->stacksize;
        sqStack->stacksize +=STACK_INCREMENT;
    }
    *sqStack->top ++ = data;
    return OK;
}

2.4,出栈函数

status pop(stack *sqStack)
{
    if(sqStack->base == sqStack->top)
    {
        return ERROR;
    }
    --sqStack->top;
    return OK;
}

2.5,取栈顶元素函数

status getTop(stack *sqStack,int *data )
{
    if(sqStack->base==sqStack->top)
        return ERROR;
    *data = *(sqStack->top-1);
    return OK;

}

2.6,销毁函数

status destroyStack(stack *sqStack)
{
    free(sqStack);
    return OK;
}

2.7,其他

status stackIsEmpty(stack *sqStack)
{
    if(sqStack->base == sqStack->top)
    {
        return OK;
    }
    return ERROR;
}


int stackLength(stack *sqStack)
{
    return sqStack->top-sqStack->base;
}


status clearStack(stack *sqStack)
{
    sqStack->top = sqStack->base;
    return OK;
}

 

三、测试

我们定义一个测试函数,进行测试:

void testStack()
{
    stack *s = (stack *)malloc(sizeof(struct Stack));
    int result = initStack(s);
    push(s,3);
    push(s,9);
    push(s,5);
    push(s,1);
    push(s,7);

    int data;
    getTop(s,data);
    printf("the top data is:%d\n",data);
    pop(s);
    getTop(s,data);
    printf("the top data is:%d\n",data);
    pop(s);
    getTop(s,data);
    printf("the top data is:%d\n",data);
    pop(s);
    getTop(s,data);
    printf("the top data is:%d\n",data);
    pop(s);
    getTop(s,data);
    printf("the top data is:%d\n",data);
    destroyStack(s);
}

    测试结果如下:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2248070.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

5.5 W5500 TCP服务端与客户端

文章目录 1、TCP介绍2、W5500简介2.1 关键函数socketlistensendgetSn_RX_RSRrecv自动心跳包检测getSn_SR 1、TCP介绍 TCP 服务端: 创建套接字[socket]:服务器首先创建一个套接字,这是网络通信的端点。绑定套接字[bind]:服务器将…

Transformer详解及衍生模型GPT|T5|LLaMa

简介 Transformer 是一种革命性的神经网络架构,首次出现在2017年的论文《Attention Is All You Need》中,由Google的研究团队提出。与传统的RNN和LSTM模型不同,Transformer完全依赖于自注意力(Self-Attention)机制来捕…

计算机网络基础全攻略:探秘网络构建块(1/10)

一、计算机网络基础概念 计算机网络是指将地理位置不同的具有独立功能的多台计算机及其外部设备,通过通信线路和通信设备连接起来,在网络操作系统,网络管理软件及网络通信协议的管理和协调下,实现资源共享和信息传递的计算机系统…

Android 应用测试的各种环境问题记录(Instrumentation测试)

报错记录 failed to configure packages targetSdkVersion(未解决) failed to configure com.demo.test.SettingsActivityTest.testOnCreate_withNullSavedInstanceState: Package targetSdkVersion34 > maxSdkVersion32 java.lang.IllegalArgumentE…

Python 爬虫从入门到(不)入狱学习笔记

爬虫的流程:从入门到入狱 1 获取网页内容1.1 发送 HTTP 请求1.2 Python 的 Requests 库1.2 实战:豆瓣电影 scrape_douban.py 2 解析网页内容2.1 HTML 网页结构2.2 Python 的 Beautiful Soup 库 3 存储或分析数据(略) 一般爬虫的基…

周志华深度森林deep forest(deep-forest)最新可安装教程,仅需在pycharm中完成,超简单安装教程

1、打开pycharm 没有pycharm的,在站内搜索安装教程即可。 2、点击“文件”“新建项目” 3、创建项目,Python版本中选择Python39。如果没有该版本,选择下面的Python 3.9下载并安装。 4、打开软件包,搜索“deep-forest”软件包&am…

用python将一个扫描pdf文件改成二值图片组成的pdf文件

使用墨水屏读书现在似乎越来越流行,这确实有一定的好处,例如基本不发热,电池续航时间超长,基本不能游戏所以有利于沉浸式阅读,还有不知道是不是真的有用的所谓防蓝光伤害。但是,如果阅读的书籍是扫描图片组…

前端---HTML(一)

HTML_网络的三大基石和html普通文本标签 1.我们要访问网络,需不需要知道,网络上的东西在哪? 为什么我们写,www.baidu.com就能找到百度了呢? 我一拼ping www.baidu.com 就拼到了ip地址: [119.75.218.70]…

电影风格城市夜景旅拍Lr调色教程,手机滤镜PS+Lightroom预设下载!

调色教程 电影风格城市夜景旅拍通过 Lightroom 调色,将城市夜晚的景色打造出如同电影画面般的质感和氛围。以独特的色彩和光影处理,展现出城市夜景的魅力与神秘。 预设信息 调色风格:电影风格预设适合类型:人像,街拍…

【多模态】Flamingo模型技术学习

Flamingo模型技术学习 前言Flamingo——支持上下文学习的多模态模型模型架构模型架构——Resampler模型架构——插入到LLM的cross-attention层 代码查看——masked cross-attentionnote 前言 最近多模态模型特别火,从头开始学习!在前面写的几篇里面学习了…

C 语言学习-06【指针】

1、目标单元与简介存取 直接访问和间接访问 #include <stdio.h>int main(void) {int a 3, *p;p &a;printf("a %d, *p %d\n", a, *p);*p 10;printf("a %d, *p %d\n", a, *p);printf("Enter a: ");scanf("%d", &a)…

ctfshow单身杯2024wp

文章目录 ctfshow单身杯2024wp签到好玩的PHPezzz_sstiez_inject ctfshow单身杯2024wp 签到好玩的PHP 考点&#xff1a;序列化反序列化 <?phperror_reporting(0);highlight_file(__FILE__);class ctfshow {private $d ;private $s ;private $b ;private $ctf ;public …

超高流量多级缓存架构设计!

文章内容已经收录在《面试进阶之路》&#xff0c;从原理出发&#xff0c;直击面试难点&#xff0c;实现更高维度的降维打击&#xff01; 文章目录 电商-多级缓存架构设计多级缓存架构介绍多级缓存请求流程负载均衡算法的选择轮询负载均衡一致性哈希负载均衡算法选择 应用层 Ngi…

【Mybatis】@Param注解 resultMap手动映射

文章目录 一、映射文件参数二、查询映射2-1 一对一2-2 一对多2-3 总结 一、映射文件参数 Param 注解官方文档解释 1、单个参数&#xff08;对象&#xff09;不使用注解 public int save(User user);<!-- 添加用户 --> <insert id"save" parameterType&quo…

Unreal从入门到精通之如何绘制用于VR的3DUI交互的手柄射线

文章目录 前言实现方式MenuLaser实现步骤1.Laser和Cursor2.移植函数3.启动逻辑4.检测射线和UI的碰撞5.激活手柄射线6.更新手柄射线位置7.隐藏手柄射线8.添加手柄的Trigger监听完整节点如下:效果图前言 之前我写过一篇文章《Unreal5从入门到精通之如何在VR中使用3DUI》,其中讲…

风尚云网前端学习:一个简易前端新手友好的HTML5页面布局与样式设计

风尚云网前端学习&#xff1a;一个简易前端新手友好的HTML5页面布局与样式设计 简介 在前端开发的世界里&#xff0c;HTML5和CSS3是构建现代网页的基石。本文将通过一个简单的HTML5页面模板&#xff0c;展示如何使用HTML5的结构化元素和CSS3的样式特性&#xff0c;来创建一个…

STM32WB55RG开发(5)----监测STM32WB连接状态

STM32WB55RG开发----5.生成 BLE 程序连接手机APP 概述硬件准备视频教学样品申请源码下载参考程序选择芯片型号配置时钟源配置时钟树RTC时钟配置RF wakeup时钟配置查看开启STM32_WPAN条件配置HSEM配置IPCC配置RTC启动RF开启蓝牙LED配置设置工程信息工程文件设置参考文档SVCCTL_A…

RK356x-10:串口(uart)配置与调试

本文记录RK3566/RK3568通用异步串口(uart)的配置与调试过程 1. 配置uart节点 1.1 在rk3568.dtsi中已经定义了uart0,uart1...&#xff0c;根据电路图&#xff0c;确定需要使用的是哪个串口&#xff0c;比如我使用的是uart0&#xff0c;在另外一个与我们自己主板相关的dtsi文件&…

【C++】从C到C++

C和C一些语法区别 1.三目运算符&#xff1a;在C语言中返回的是一个常量&#xff0c;是不能被赋值的&#xff1b;而C中返回的是变量&#xff0c;可以被赋值 2.C中的函数必须要写返回值类型 3.在全局下&#xff0c;C不允许int a;和int a10;等这种重定义二义性操作 4.在C中不要…

WSL安装不同版本ubuntu(已有ubuntu20.04,再装ubuntu18.04)

参考&#xff1a; 如何在 WSL 中删除指定版本的 Ubuntu&#xff08;以删除 Ubuntu 22.04 为例&#xff09;_wsl卸载某个-CSDN博客 已有ubuntu20.04&#xff0c;现在再安装一个ubuntu18.04 直接参考下面我写的链接的第四步&#xff0c;前面的步骤都不需要再做了 Win11安装WSL…