第五周 项目1

来源:互联网 发布:基于大数据用户画像 编辑:程序博客网 时间:2024/06/05 04:05

问题及描述:

   

/*  烟台大学计算机学院    文件名称:ycddd.cpp    作者:范宝磊   完成日期:2017年10月6日    问题描述:定义顺序栈存储结构,实现其基本运算  输入描述:无  输出描述:顺序栈的操作以及栈的操作后的元素输出,以及出栈的元素输出   */           main:      #include <stdio.h>  #include "stlist.h"  int main()  {      ElemType e;      SqStack *s;      printf("(1)初始化栈s\n");      InitStack(s);      printf("(2)栈为%s\n",(StackEmpty(s)?"空":"非空"));      printf("(3)依次进栈元素a,b,c,d,e\n");      Push(s,'a');      Push(s,'b');      Push(s,'c');      Push(s,'d');      Push(s,'e');      printf("(4)栈为%s\n",(StackEmpty(s)?"空":"非空"));      printf("(5)栈长度:%d\n",StackLength(s));      printf("(6)从栈顶到栈底元素:");DispStack(s);      printf("(7)出栈序列:");      while (!StackEmpty(s))      {          Pop(s,e);          printf("%c ",e);      }      printf("\n");      printf("(8)栈为%s\n",(StackEmpty(s)?"空":"非空"));      printf("(9)释放栈\n");      DestroyStack(s);      return 0;  }        stlist.cpp:    #include <stdio.h>  #include <malloc.h>  #include "stlist.h"    void InitStack(SqStack *&s)  {      s=(SqStack *)malloc(sizeof(SqStack));      s->top=-1;  }  void DestroyStack(SqStack *&s)  {      free(s);  }  int StackLength(SqStack *s)  //返回栈中元素个数——栈长度  {      return(s->top+1);  }  bool StackEmpty(SqStack *s)  {      return(s->top==-1);  }  bool Push(SqStack *&s,ElemType e)  {      if (s->top==MaxSize-1)    //栈满的情况,即栈上溢出          return false;      s->top++;      s->data[s->top]=e;      return true;  }  bool Pop(SqStack *&s,ElemType &e)  {      if (s->top==-1)     //栈为空的情况,即栈下溢出          return false;      e=s->data[s->top];      s->top--;      return true;  }  bool GetTop(SqStack *s,ElemType &e)  {      if (s->top==-1)         //栈为空的情况,即栈下溢出          return false;      e=s->data[s->top];      return true;  }    void DispStack(SqStack *s)  //输出栈  {      int i;      for (i=s->top;i>=0;i--)          printf("%c ",s->data[i]);      printf("\n");  }          stlist.h:    #define MaxSize 100  typedef char ElemType;  typedef struct  {      ElemType data[MaxSize];      int top;                //栈指针  } SqStack;                  //顺序栈类型定义    void InitStack(SqStack *&s);    //初始化栈  void DestroyStack(SqStack *&s);  //销毁栈  bool StackEmpty(SqStack *s);     //栈是否为空  int StackLength(SqStack *s);  //返回栈中元素个数——栈长度  bool Push(SqStack *&s,ElemType e); //入栈  bool Pop(SqStack *&s,ElemType &e); //出栈  bool GetTop(SqStack *s,ElemType &e); //取栈顶数据元素  void DispStack(SqStack *s);  //输出栈  
运行及结果:
   
  学习心得:
     
     通过学习如何建立顺序栈算法库,学会了如何使用顺序栈的算法来编写程序运行

原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 6岁儿童头有点歪怎么办 宝宝脖子有点偏左边歪怎么办 宝宝脖子偏了怎么办呢 斜颈导致的脸歪怎么办 斜颈手术后脸部还不对称怎么办 宝宝3个月斜颈怎么办 一岁八个月宝宝斜颈怎么办 四个月宝宝有点斜颈怎么办 一岁宝宝有点偏怎么办 6个月宝宝有点斜颈怎么办 四个月宝宝左侧胸锁乳突肌厚怎么办 脖子疼好几天了怎么办 有双下巴怎么办才能瘦掉 胃突然疼的厉害怎么办 手劳损痛的厉害怎么办 手臂扭到了很疼怎么办 寒湿导致肩膀痛怎么办 吃辣脖子肿了怎么办 脖子长了个肿瘤怎么办 一边背高一边低怎么办 生完孩子肩宽了怎么办 狗狗脖子上长囊肿怎么办 胸肋关节韧带疼怎么办 三岁宝宝有点驼背怎么办 20多岁有点驼背怎么办 五岁宝宝有点驼背怎么办 孕妇腰扭了很痛怎么办 怀孕了腰扭了疼怎么办 小龙芭比扭腰机开机没有声音怎么办 高中生训练数学计算的准确性怎么办 跑步累了跑不动了怎么办 一跑步就岔气了怎么办 婴儿关节折邹发红怎么办? 打了借条人跑了怎么办 吃凉的胃不舒服怎么办 跑步机带子跑偏怎么办 在跑步机上摔倒怎么办 弯道以后就是直线行驶怎么办 跑步机的声音大怎么办 科二一直考不过怎么办 考科目三太紧张怎么办