数据结构实验报告5
更新时间:2024-05-26 18:00:01 阅读量: 综合文库 文档下载
数据结构实验报告——实验5
学号: 姓名: 得分:______________
一、实验目的
1、复习栈的逻辑结构、存储结构及基本操作; 2、掌握顺序栈、链栈。
二、实验内容
1、(必做题)假设栈中数据元素类型是字符型,请采用顺序栈实现栈的以下基本操作: (1)Status InitStack (&S) //构造空栈S; (2)Status Push(&S, e) //元素e入栈S;
(3)Status Pop(&S, &e) //栈S出栈,元素为e。 2、(必做题)请实现:对于一个可能包括括号{}、[]、()的表达式,判定其中括号是否匹配。
三、算法描述
(采用自然语言描述)
1. 构建空栈s,输入元素,将元素依次入栈,遍历打印栈中元素,输出栈顶元素,打印被输出的元素,遍历打印栈中元素。
2.构建空栈,输入表达式,使用函数count判断表达式中括号是否匹配,如果匹配输出匹配正确,不匹配则输出匹配错误。
四、详细设计
1.
开始 构建空栈s 输入元素 将元素依次入栈 遍历打印栈中元素 输出栈顶元素 打印被输出的元素 遍历打印栈中元素 结束 1
2.
开始 构建空栈s 输入表达式 使用函数count判断表达式中括号是否匹配 输出匹配错误 输出匹配正确 结束
五、程序代码
(给出必要注释) 1.
#include
typedef struct node* SqStack; typedef char ElemType;
struct node//栈的数据结构 {
int top;
ElemType data[MaxSize]; };
void StatusInitStack(SqStack *L)//构造空栈S {
(*L) = (SqStack*)malloc(sizeof(SqStack)); (*L)->top = -1; }
2
void StatusPush(SqStack L, ElemType e)//元素e入栈S {
if (L->top == MaxSize - 1) {
printf(\栈满\\n\ } else {
L->top++;
L->data[L->top] = e; } }
void StatusPop(SqStack L, ElemType *e)//栈S出栈,元素为e {
if (L->top == -1) {
printf(\栈空\\n\ } else {
*e = L->data[L->top]; L->top--; } }
void Print(SqStack L)//遍历输出 {
int i = 0;
for(i = 0; i <= L->top; i++) {
printf(\ }
printf(\}
int main() {
SqStack s; ElemType e; ElemType* y; y = &e;
StatusInitStack(&s);
printf(\输入入栈数据:\ scanf(\
3
while (e!='\\n') {
StatusPush(s, e); scanf(\ }
printf(\目前栈中元素为:\\n\ Print(s);
StatusPop(s, y);
printf(\出栈元素是:%c\\n\
printf(\栈顶元素出栈后,栈为:\\n\ Print(s); } 2.
#include
#define STACK_INIT_SIZE 10 #define STACK_GROW_SIZE 5 #define ELEMTYPE char
typedef struct /*建立一个栈的首结点*/ {
ELEMTYPE * base; ELEMTYPE * top; int stacksize; } SpStack;
int InitStack(SpStack *s) /*建立空的栈并返回首地址*/ {
s->base=((ELEMTYPE*)malloc(STACK_INIT_SIZE*sizeof(ELEMTYPE))); if (!s->base) return 0; s->top=s->base;
s->stacksize=STACK_INIT_SIZE; return 1; }
int StackEmpty(SpStack *s) /*判断栈是否为空*/ {
if (s->top==s->base) return 1; else return 0; }
int Push(SpStack *s,ELEMTYPE e) /*往栈顶插入元素即进栈*/
4
{
if (s->top-s->base>=s->stacksize) /*判断是否栈满*/ {
s->base=((ELEMTYPE*)realloc(s->base,(s->stacksize+STACK_GROW_SIZE)*sizeof(ELEMTYPE))); if (!s->base) return 0;
s->stacksize+=STACK_GROW_SIZE; s->top=s->base+s->stacksize; }
*s->top++=e; return 1; }
int Pop(SpStack *s,ELEMTYPE *e) /*让栈顶元素依次输出即出栈*/ {
if (StackEmpty(s)) return 0; *e=*(--s->top); return 1; }
int Count(SpStack *s) {
ELEMTYPE e[STACK_INIT_SIZE*2]; ELEMTYPE e1; int i;
InitStack(s); gets(e);
if ('\\n'==e[strlen(e)-1]) e[strlen(e)-1]=0; for (i=0; e[i]!='\\0'; i++) {
switch (e[i]) {
case '(': case '[': case '{':
Push(s,e[i]); break; case ')': case ']': case '}':
if(StackEmpty(s)) {
printf(\匹配错误\\n\
5
return 0; }
else Pop(s,&e1); break; } }
if (StackEmpty(s)) {
printf(\匹配正确\\n\ return 1; } else {
printf(\匹配错误\\n\ return 0; } }
int main() {
SpStack s;
printf(\请输入一个可能包括括号{}、[]、()的表达式\\n\ Count(&s); free(s.base); return 0; }
六、测试和结果
(给出测试用例,并给出测试结果) 1. 2.
七、用户手册
6
(告诉用户如何使用程序,使用注意事项等)
1. 第二个程序输入时需注意表达式不得长于10个单位; 2. 第一个程序输入时需注意表达式不得长于100个单位;
7
正在阅读:
数据结构实验报告505-26
感慨六年级心情日记10-29
重庆市第四届中小学生科技节09-27
中考课内古诗词填空 浙教版06-01
公文写作能力测试题04-26
DAT28─2002 国家重大建设项目文件归档要求与档案整理规范05-21
内蒙古游记作文400字07-06
高中数学第三册(选修Ⅱ)第3章导数几种常见函数的导数练习题09-04
胜利一中七年级预备级测试卷Test for Starter Units 203-13
爱因斯坦谜题:谁养鱼(C#版)12-18
- 多层物业服务方案
- (审判实务)习惯法与少数民族地区民间纠纷解决问题(孙 潋)
- 人教版新课标六年级下册语文全册教案
- 词语打卡
- photoshop实习报告
- 钢结构设计原理综合测试2
- 2014年期末练习题
- 高中数学中的逆向思维解题方法探讨
- 名师原创 全国通用2014-2015学年高二寒假作业 政治(一)Word版
- 北航《建筑结构检测鉴定与加固》在线作业三
- XX县卫生监督所工程建设项目可行性研究报告
- 小学四年级观察作文经典评语
- 浅谈110KV变电站电气一次设计-程泉焱(1)
- 安全员考试题库
- 国家电网公司变电运维管理规定(试行)
- 义务教育课程标准稿征求意见提纲
- 教学秘书面试技巧
- 钢结构工程施工组织设计
- 水利工程概论论文
- 09届九年级数学第四次模拟试卷
- 数据结构
- 实验
- 报告
- 南财计量经济学课后习题答案_郭存芝_杜延军_李春吉
- 藏木电站总体施工组织
- 山东省淄博第一中学2018届高三上学期期中考试生物试题 Word版含
- 2017年滴眼液发展现状及市场前景分析 (目录)
- 档案借、查阅制度
- 邮政储蓄竞赛试题
- 造影剂分类及优缺点
- 电子教案
- 管理会计练习
- 所有佛法精华中的总精华是什么? 八
- 高速公路服务区管理制度
- 基础化学题库
- 鸭养殖技术与操作规范
- 兰大《卫生统计学》16秋平时作业2
- 第二章 地球上的大气综合练习
- 【毕业论文】基于matlab的人脸识别系统设计与仿真(含matlab源程
- 2012-2013年中国货币政策分析与展望
- 统计学 时间序列分析
- 广东省广州市2017-2018学年第一学期天河区八年级期末英语试卷及
- 王国维研究参考书目——很全很全