news 2026/5/4 8:18:01

线性表之顺序栈

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
线性表之顺序栈
  • 栈是限制在一端进行插入操作和删除操作的线性表(俗称堆栈)
  • 允许进行操作的一端称为”栈顶“
  • 另一固定端称为”栈底“
  • 当栈中没有元素时称为”空栈“
  • 特点:后进先出(LIFO)或先进后出

  • 顺序栈是顺序表的一种,具有顺序表同样的存储结构,由数组定义,配合用数组下标表示的栈顶指针top(相对指针)完成各种操作
typedefintdata_t;/*定义栈中数据元素的数据类型*/typedefstruct{data_t*data;/*用指针指向栈的存储空间*/intmaxlen;/*当前栈的最大元素个数*/inttop;/*指示栈顶位置(数组下标)的变量*/}sqstack;/*顺序栈类型定义*/

顺序栈

功能代码

#include<stdio.h>#include<stdlib.h>#include<string.h>#include"sqstack.h"sqstack*stack_create(intlen){sqstack*s;if((s=(sqstack*)malloc(sizeof(sqstack)))==NULL){printf("malloc sqstack failed\n");returnNULL;}if((s->data=(data_t*)malloc(len*sizeof(data_t)))==NULL){printf("malloc data failed\n");free(s);returnNULL;}memset(s->data,0,len*sizeof(data_t));s->maxlen=len;s->top=-1;returns;}intstack_push(sqstack*s,data_tvalue){if(s==NULL){printf("s is NULL\n");return-1;}if(s->top==s->maxlen-1){printf("stack is full\n");return-1;}s->top++;s->data[s->top]=value;return0;}intstack_empty(sqstack*s){if(s==NULL){printf("s is NULL\n");return-1;}return(s->top==-1?1:0);}intstack_full(sqstack*s){if(s==NULL){printf("s is NULL\n");return-1;}return(s->top==s->maxlen-1?1:0);}data_tstack_pop(sqstack*s){s->top--;return(s->data[s->top+1]);}data_tstack_top(sqstack*s){return(s->data[s->top]);}intstack_clear(sqstack*s){if(s==NULL){printf("s is NULL\n");return-1;}s->top=-1;return0;}intstack_free(sqstack*s){if(s==NULL){printf("s is NULL\n");return-1;}if(s->data!=NULL){free(s->data);}free(s);return0;}

头文件

typedefintdata_t;typedefstruct{data_t*data;intmaxlen;inttop;}sqstack;sqstack*stack_create(intlen);intstack_push(sqstack*s,data_tvalue);intstack_empty(sqstack*s);intstack_full(sqstack*s);data_tstack_pop(sqstack*s);data_tstack_top(sqstack*s);intstack_clear(sqstack*s);intstack_free(sqstack*s);

测试文件

#include<stdio.h>#include"sqstack.h"intmain(intargc,constchar*argv[]){sqstack*s;s=stack_create(100);if(s==NULL)return-1;stack_push(s,10);stack_push(s,20);stack_push(s,30);stack_push(s,40);while(!stack_empty(s)){printf("pop: %d \n",stack_pop(s));}stack_free(s);return0;}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/20 7:16:18

线性表之链式栈

插入操作和删除操作均在链表头部进行&#xff0c;链表尾部就是栈底&#xff0c;栈顶指针就是头指针不需要预先分配固定大小动态增长和收缩typedef int data_t ; /*定义栈中数据元素数据类型*/ typedef struct node_t {data_t data ; /*数据域*/struct node_t *ne…

作者头像 李华
网站建设 2026/5/1 8:46:32

岩土颗粒粗糙度计算,采用傅里叶展开。 matlab源代码 生成颗粒均方根粗糙度,算术平均粗糙度

岩土颗粒粗糙度计算&#xff0c;采用傅里叶展开。 matlab源代码 生成颗粒均方根粗糙度&#xff0c;算术平均粗糙度。 方法来自《非规则颗粒形态表征与离散元模拟方法的研究》清华大学出版社 matalb源代码傅里叶展开在岩土颗粒形态分析中的应用挺有意思。咱们今天直接上干货&…

作者头像 李华
网站建设 2026/4/24 5:07:35

GTN损伤模型在金属成型中的实战改造手记

修正的考虑剪切和静水压力的各向异性和各向同性 GTN 模型 Abaqus_Vumat 子程序以及跑通的案例&#xff0c;包括 三个子程序 for 文件&#xff08;各向同性&#xff0c;自己推导修改以及各向异性&#xff09; 、cae 文件和 inp 文件等&#xff0c;还有一些论文资料。 注&#x…

作者头像 李华
网站建设 2026/4/21 5:41:12

怎么清洗角膜塑形镜才有效?

在本文中&#xff0c;我们将深入探讨如何有效清洗OK镜&#xff0c;确保其保持最佳性能。清洗不仅能延长镜片的使用寿命&#xff0c;还能避免细菌的滋生&#xff0c;从而保护眼睛健康。此外&#xff0c;在使用角膜塑形镜时&#xff0c;家长需特别关注孩子的使用注意事项&#xf…

作者头像 李华
网站建设 2026/4/24 15:55:52

leetcode56.合并区间

以数组 intervals 表示若干个区间的集合&#xff0c;其中单个区间为 intervals[i] [starti, endi] 。请你合并所有重叠的区间&#xff0c;并返回 一个不重叠的区间数组&#xff0c;该数组需恰好覆盖输入中的所有区间 。示例 1&#xff1a; 输入&#xff1a;intervals [[1,3],…

作者头像 李华
网站建设 2026/5/2 7:11:27

云手机存在哪些技术瓶颈

云手机需在服务器上虚拟化出与真实手机一致的运行环境&#xff0c;目前多采用 ARM 服务器方案&#xff0c;但相关技术迁移尚未完全普及&#xff0c;仍存在硬件功耗、能效比等方面的问题&#xff0c;且对移动端应用的兼容性有待提升&#xff0c;可能出现游戏渲染卡顿、多任务切换…

作者头像 李华