实现顺序栈的各种基本运算;其次设计程序调用顺序栈的这些算法进行功能测试。用c语言

时间: 2024-12-08 07:17:27 浏览: 29

在 C 语言中,我们可以创建一个简单的顺序栈数据结构,并实现常见的栈操作,如压入元素(push)、弹出元素(pop)、查看顶部元素(peek 或 top)以及检查栈是否为空(is_empty)。这里是一个基础的顺序栈实现示例:

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

// 定义栈的最大容量
#define MAX_CAPACITY 50

// 结构体定义栈
typedef struct Stack {
    int capacity;
    int* items; // 存储栈元素的数组
    int top;     // 栈顶指针
} Stack;

// 初始化栈
Stack* stack_create() {
    Stack* s = (Stack*)malloc(sizeof(Stack));
    if (!s) {
        printf("Memory allocation failed.\n");
        return NULL;
    }
    s->capacity = MAX_CAPACITY;
    s->items = (int*)malloc(s->capacity * sizeof(int));
    if (!s->items) {
        free(s);
        printf("Memory allocation for items failed.\n");
        return NULL;
    }
    s->top = -1;
    return s;
}

// 空栈检测
int is_empty(Stack* s) {
    return s->top == -1;
}

// 入栈(push)
void push(Stack* s, int value) {
    if (s->top == s->capacity - 1) {
        printf("Stack is full, can't push.\n");
        return;
    }
    s->items[++s->top] = value;
}

// 出栈(pop)
int pop(Stack* s) {
    if (is_empty(s)) {
        printf("Stack is empty, can't pop.\n");
        return -1;
    }
    return s->items[s->top--];
}

// 查看栈顶元素(peek)
int peek(Stack* s) {
    if (is_empty(s)) {
        printf("Stack is empty, no element to peek.\n");
        return -1;
    }
    return s->items[s->top];
}

// 销毁栈
void stack_destroy(Stack* s) {
    free(s->items);
    free(s);
}

int main() {
    Stack* stack = stack_create();
    
    // 功能测试
    if (!stack) {
        return 1;
    }

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

    printf("Top element: %d\n", peek(stack)); // 输出: Top element: 3
    
    printf("Popped element: %d\n", pop(stack)); // 输出: Popped element: 3
    printf("After popping: Top element is %d\n", peek(stack)); // 输出: After popping: Top element is 2

    stack_destroy(stack);
    return 0;
}
向AI提问 loading 发送消息图标

相关推荐

大学生入口

大家在看

recommend-type

Macrar Winrar Mac版 v5.1.0

Winrar mac版是WinRAR为Mac平台开发的一款功能强大的压缩包管理器,它是档案工具RAR 在 Windows 环境下的图形界面,Winrar可以让你根据需要,将压缩后的文件保存为ZIP或RAR的格式。注意事项
recommend-type

vosk-browser:借助Vosk的WebAssembly构建,浏览器中运行的语音识别库

Vosk浏览器 使用的WebAssembly构建的针对浏览器的自以为是的语音识别库 该库负责所做的工作,并将更新的Vosk WebAssembly构建打包为易于使用的浏览器库。 注意:WebAssembly构建可以针对NodeJS,浏览器的主线程或Web Worker。 该库显式编译了Vosk以在WebWorker上下文中使用。 如果要在NodeJS应用程序中使用Vosk,建议使用官方。 现场演示 以13种语言签出演示运行在浏览器内的麦克风输入或音频文件的浏览器语音识别的演示。 安装 您可以将vosk-browser作为模块安装: $ npm i vosk-browser 您还可以使用jsdelivr这样的CDN将库添加到页面中,可以通过全局变量Vosk访问该Vosk : &lt;script type="application/javascript" src="https://cdn.j
recommend-type

运动控制卡手册2019.11.14.pdf

三菱运动控制卡手册,可以使用JE J4驱动器,各种参数说明,三菱运动控制卡手册,可以使用JE J4驱动器,各种参数说明,
recommend-type

Silabs_Headunit_V3.2.3734 for A55.zip

si47xx驱动源代码 稍作修改即可使用到产品中去!车机开发人员懂得
recommend-type

ULA_主瓣干扰_主瓣干扰抑制_

使用JADE算法对L型阵列接收信号实现主瓣干扰抑制

最新推荐

recommend-type

表达式求值顺序栈实现包括小数点运算(C语言版).docx

该文档涉及的知识点主要集中在C语言中如何使用顺序栈实现表达式求值,特别是涉及到小数点运算。这里我们将详细探讨这个过程。 首先,我们创建了两个顺序栈:`seqstack optr` 和 `seqstack opnd`。`optr` 用于存储...
recommend-type

C语言接口与实现方法实例详解

接口定义了模块的功能,实现则提供了这些功能的具体算法和数据结构。良好的接口设计可以减少不必要的耦合,提高代码的稳定性和可移植性。而实现的灵活性则允许在不改变接口的情况下优化和调整内部逻辑,以提高性能或...
recommend-type

C语言程序设计 存储管理分区分配算法

在本课程设计中,主题聚焦于“C语言程序设计 存储管理分区分配算法”,旨在深化学生对C语言的理解,并提升其在实际问题中的应用能力。C语言是一种强大的编程语言,广泛应用于系统开发、嵌入式系统、软件工程等多个...
recommend-type

基于Matlab/Simulink的风电调频与风储联合频域模型仿真及应用

内容概要:本文介绍了利用Matlab/Simulink进行风电调频与风储联合仿真的方法。针对传统时域仿真耗时的问题,提出了一种基于频域模型的方法,实现了快速高效的仿真。文中详细描述了虚拟惯性控制和储能下垂控制的具体实现方式及其对系统频率稳定性的影响。通过频域模型,将复杂的微分方程转化为简单的矩阵运算,显著提高了仿真速度。同时,加入了SOC(荷电状态)管理和滑动平均滤波,确保了储能系统的安全可靠运行。实验结果显示,在相同的硬件条件下,频域模型的仿真速度比传统时域模型快了近十倍,且频率偏差明显减小。 适合人群:从事电力系统仿真、风电调频研究的专业人士和技术爱好者。 使用场景及目标:适用于需要快速验证风电调频控制策略的研究人员和工程师。主要目标是在保证仿真精度的同时大幅提高仿真速度,为风电并网提供技术支持。 其他说明:本文提供的模型专注于调频性能分析,不涉及风机内部动态细节。对于更详细的风机模型,作者提供了进一步的参考资料。
recommend-type

六个信息系统开发案例深度解析

### 知识点分析 #### 标题知识点: - **信息系统开发** 信息系统开发是计算机科学领域中的一个重要分支,涉及利用计算机技术、软件工程、数据库管理、网络通信等多个方面的知识,设计、构建、部署和维护信息系统。系统开发周期通常包括需求分析、设计、编码、测试、部署和维护几个阶段。信息系统广泛应用于各行各业,旨在提高数据处理效率、优化业务流程、提升决策质量等。 - **实例精粹** “实例精粹”意味着本文件将通过具体的案例来展示信息系统开发的过程和成果。实例可以提供直观的学习材料,使读者能够更好地理解理论知识与实践操作之间的联系,以及如何在实际项目中运用信息系统开发的技术和方法。 - **My Disc** “My Disc”可能是本文件中的一个特定的信息系统名称或者是一个主题词。由于信息不足,无法确定“My Disc”具体指代什么,但可以合理推测,它可能是书中用来说明各个信息系统的开发实例中的一个,用于存储和管理数据,比如音乐、视频、软件等数字内容。 #### 描述知识点: - **运输信息系统** 运输信息系统通常用于管理货物或乘客的运输过程。这种系统可以是用于车队管理、物流跟踪、票务预订等。一个典型的运输信息系统可能包括订单管理、车辆调度、路线优化、货物追踪、乘客服务管理等功能模块。 - **宾馆信息系统** 宾馆信息系统是专门为宾馆行业设计的系统,用于管理客房预订、登记入住、账务处理、客户关系、餐饮服务等。此类系统的开发需要考虑如何高效地处理客户信息,以及如何确保宾馆日常运营的自动化和智能化。 - **学生信息系统** 学生信息系统是教育机构中不可或缺的一部分,用于学生个人信息、学籍管理、成绩跟踪、课程安排、学费管理等方面。它需要保证信息的安全性和准确性,同时为学生、教师和管理员提供便捷的操作界面。 描述中提到的“运输的、宾馆的、学生的”等信息表明该文档将包含多个不同领域中的信息系统开发实例,每个实例都以一个行业为背景,反映了信息系统在各行业中的应用和作用。 #### 标签知识点: - **信息系统开发** 标签再次强调了文件的核心内容是关于信息系统的开发。这可能涉及开发方法论(如敏捷开发、瀑布模型等)、开发工具(如数据库管理系统、编程语言、项目管理软件等)和技术框架(如微服务架构、SOA服务导向架构等)。 - **实例精粹** 通过实例来呈现知识,这是学习和教育中非常有效的方式。实例可以是项目案例研究、技术演示、需求分析、设计模式应用、编码实现、系统测试和部署等。每个实例都精心挑选,以反映信息系统开发的关键知识点和最佳实践。 #### 压缩包子文件的文件名称列表知识点: - **文件名称:信息系统开发实例精粹:My Disc** 这个文件名称信息与标题相似,但这里需要注意的是,“压缩包子文件”的表述可能是一个翻译错误或者是指文件压缩包的命名方式。如果是一个压缩包,那么它可能包含了多个关于信息系统开发实例的文档、代码、数据库脚本、截图等材料,便于用户下载和学习。 ### 综合分析 从标题、描述、标签和文件名称列表所提供的信息来看,该文件是一本关于信息系统开发案例的集合,涵盖了不同行业领域中的信息系统应用实例。每个实例都旨在具体阐述信息系统开发的某个方面或阶段,并通过详细的案例分析,提供给读者实际的开发场景和解决方案,以加深对信息系统开发理论和实践操作的理解。 具体到每一个案例,例如运输信息系统可能重点讨论了如何通过信息系统来优化物流管理、提升货物配送效率;宾馆信息系统可能着重于如何通过自动化流程来提高客户服务质量和后台管理效率;学生信息系统则可能关注如何利用信息系统来提升教育质量和学生管理的便捷性。各个案例详细说明了需求分析、系统设计、功能实现、用户测试和最终部署等各个阶段的实施细节。 本文件通过不同实例的精粹,不仅能够帮助读者理解信息系统开发的流程和技术,还能够指导读者如何应对实际开发中可能遇到的问题和挑战,从而提升解决实际问题的能力。这对于信息系统开发的初学者和专业人士都具有很大的参考价值。
recommend-type

帧间最小间隔的测量方法:评估网络性能的5大技巧

# 摘要 网络性能评估是确保网络可靠性和效率的关键环节,其中帧间最小间隔是影响网络性能的重要因素。本文首先介绍了帧间最小间隔的概念及其在网络性能评估中的重要性,然后探讨了与网络协议的关系,并着重阐述了测量帧间最小间隔的多种工具与方法。在此基础上,文章进一步提供了五种高级网络性能评估技巧,包括多点监测、实时流量模拟、延迟测量、拥塞控制和安全性评估。最后,通过三个实战案例分析,
recommend-type

vmware系统找不到指定文件,模块disk启动失败怎么办

<think>好的,用户遇到了VMware中模块disk启动失败的问题,提示系统找不到指定文件。我需要先分析可能的原因,然后逐步给出解决方法。 首先,可能的原因包括虚拟机文件损坏、VMware服务未正确运行、磁盘驱动问题或系统权限问题。根据经验,检查虚拟机配置文件(如.vmx)是否正确,以及相关文件是否存在。此外,VMware服务如果没有启动,也可能导致此类错误。 接下来,常见的解决步骤包括:重新生成虚拟机配置文件,确保VMware服务正常运行,检查磁盘路径是否正确,以及修复或重新安装VMware。同时,用户提到的引用[1]提到了类似错误,建议参考社区中的解决方案,比如检查文件路径和重新配
recommend-type

电子报订阅服务:便捷的HTML邮箱注册方式

从给定文件信息中,我们可以提炼出关于“订阅电子报”的HTML实现知识点。虽然提供的信息有限,但我们可以围绕“订阅电子报”这一主题,展开对HTML代码实现的详细说明。以下是对相关知识点的详细阐述: ### HTML表单基础 在实现电子报订阅功能时,通常会使用HTML表单(form)元素。表单允许用户输入数据,并将数据发送到服务器。一个基本的HTML表单包括如下元素: - `<form>`:定义一个表单,它包含需要提交给服务器的表单元素。 - `<input>`:用于收集用户输入,类型可以是文本、密码、电子邮件、提交按钮等。 - `<label>`:为输入字段定义标签,提高可用性,通常与`<input>`元素配合使用。 - `<button>` 或 `<input type="submit">`:用于提交表单的按钮。 - `<textarea>`:用于输入多行文本。 ### 邮件订阅表单设计 在设计订阅电子报的表单时,需要考虑以下关键点: - **表单字段设计**:最基础的表单至少包含一个用于输入电子邮件地址的文本字段和一个提交按钮。 - **表单验证**:通过HTML5的内置验证属性(如`required`、`type="email"`)确保用户输入有效的电子邮件地址。 - **用户友好的提示信息**:提供明确的提示信息,比如“请输入您的电子邮件地址”和“订阅我们的新闻简报”。 - **响应式设计**:确保表单在不同设备(如手机、平板、桌面电脑)上均能良好显示和操作。 ### 表单标签和输入元素 - **<form>元素**:必须指定一个`action`属性,该属性定义了数据提交到的URL,以及一个`method`属性,常见的有GET和POST方法。 - **<input>元素**:是创建表单字段的核心。`type`属性定义了字段的类型,如`email`类型专门用于输入电子邮件地址,`submit`类型用于创建提交按钮。 - **<label>元素**:`for`属性需要与对应`<input>`元素的`id`属性值相同,以确保点击标签即可选中相应的输入字段。 - **<button>元素**:可以包含文本和图形,提供更多的自定义选项。 ### 示例HTML代码 ```html <form action="/subscribe" method="post"> <label for="newsletter-email">订阅我们的电子报:</label> <input type="email" id="newsletter-email" name="newsletter-email" required> <button type="submit">订阅</button> </form> ``` ### HTML5新特性对表单的增强 HTML5为表单元素引入了许多新特性,使得创建表单更加方便和强大: - **新增的输入类型**:如`email`、`url`、`date`等,提供了更好的输入校验。 - **新增的属性**:例如`required`、`pattern`、`placeholder`等,使得前端表单验证成为可能。 - **表单控件的CSS样式**:可以应用更多的样式,比如边框、颜色、阴影等,以符合网站的整体设计。 ### 安全性和隐私 在处理用户的电子邮件地址时,开发者必须遵守相关的数据保护法规,如GDPR(通用数据保护条例)。这意味着必须: - 明确告知用户其数据将如何被使用。 - 提供一个取消订阅的选项。 - 确保数据的安全传输,例如使用HTTPS协议。 ### 结论 通过上述内容,我们了解了HTML实现订阅电子报功能的基础和进阶知识点。从表单设计到数据验证,再到用户体验和隐私保护,每一个环节都是确保电子报订阅功能成功且符合规范的关键。开发者需要综合运用这些知识,构建既美观又实用的订阅界面,同时确保用户数据的安全。
recommend-type

帧间最小间隔在网络性能监测中的应用:实时数据流分析的3种实用工具

# 摘要 本文深入探讨了帧间最小间隔在网络性能监测和实时数据流分析中的关键作用。从理论基础到实用工具应用,文章分析了帧间最小间隔的定义、计算方法以及在网络性能影响方面的重要性。同时,本文介绍了实时数据流分析的基本原理和数据采集处理技术,并重点讨论了几种实用的数据流分析工具,例如Wireshark、Nagios和PRTG
recommend-type

splice函数

### 关于 `splice()` 函数的使用方法 `splice()` 是 JavaScript 中一种非常灵活的方法,主要用于修改数组的内容。它可以用来删除、添加或替换数组中的元素,并且会直接影响原始数组。 #### 1. 基本语法 其基本语法如下所示: ```javascript array.splice(start, deleteCount, item1, item2, ...); ``` - **start**: 表示从哪个索引位置开始操作。如果该参数为负数,则表示从数组末尾向前计算的位置[^2]。 - **deleteCount**: 可选参数,指定要删除的元素数量。如果不提
手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部