野火电子论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 6789|回复: 2

采用stm32工程的数据结构C实现栈的操作

[复制链接]
发表于 2016-10-10 10:03:06 | 显示全部楼层 |阅读模式
本帖最后由 challee 于 2016-10-10 10:56 编辑

  1. /************************************************************************
  2. **  顺序栈操作函数
  3. **顺序栈常作为任务PCB记录数据结构使用,在UCOS等等操作系统中常见。下面是栈的基本操作函数
  4. ******************************************************************************/
  5. #include "stack.h"
  6. #define StackSize 100   //定义栈的大小
  7. typedef char DataType;
  8. typedef struct {
  9.         DataType data[StackSize];   //栈的数据域
  10.         int top; //栈顶指针
  11. }SeqStack;
  12. void InitStack(SeqStack *S) //初始化栈
  13. {
  14.         S->top=-1;       //将栈顶元素移到栈底的下一个元素
  15. }
  16. int StackEmpty(SeqStack *S)  //判栈空
  17. {
  18.         return S->top==-1;
  19.       
  20. }
  21. int StackFull(SeqStack *S)     //判断栈是否上溢
  22. {
  23.         return S->top==StackSize-1;
  24. }
  25. void Push(SeqStack *S,DataType x)   //进展操作
  26. {
  27.         if(StackFull(S))
  28.                 printf("Stack overflow");
  29.         S->data[++(S->top)]=x;      //将插入数据赋值给数据域,并将栈顶指针上移
  30. }
  31. DataType Pop(SeqStack *S)              //出栈操作
  32. {
  33.         if(StackEmpty(S))
  34.                 printf("Stack underflow");
  35.         return S->data[S->top--];       //返回栈顶元素,并将栈顶指针下移
  36. }
  37. DataType StackTop(SeqStack *S)   //返回栈顶元素
  38. {
  39.         if(StackEmpty(S))
  40.                 printf("Stack is empty");
  41.         return S->data[S->top];
  42. }
复制代码
回复

使用道具 举报

发表于 2016-10-10 10:33:58 | 显示全部楼层
帮顶,好歹也加些文字说明下啊,超神
回复 支持 反对

使用道具 举报

 楼主| 发表于 2016-10-10 10:41:30 | 显示全部楼层
fire 发表于 2016-10-10 10:33
帮顶,好歹也加些文字说明下啊,超神

哈哈。 好。我刚刚比较忙就直接传上去了。 我这会来加注释
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

联系站长|手机版|野火电子官网|野火淘宝店铺|野火电子论坛 ( 粤ICP备14069197号 ) 大学生ARM嵌入式2群

GMT+8, 2024-5-17 12:33 , Processed in 0.042257 second(s), 24 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表