栈和队列的基本操作及其应用_第1页
栈和队列的基本操作及其应用_第2页
栈和队列的基本操作及其应用_第3页
栈和队列的基本操作及其应用_第4页
栈和队列的基本操作及其应用_第5页
全文预览已结束

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、实验二 栈和队列的基本操作及其应用一、实验目的1、掌握栈和队列的顺序存储结构和链式存储结构,以便在实际中灵活应用。2、掌握栈和队列的特点,即后进先出和先进先出的原则。3、掌握栈和队列的基本运算,如:入栈与出栈,入队与出队等运算在顺序存储结构和链式存储结构上的实现。二、实验内容1、问题描述对于一个从键盘输入的字符串,判断其是否为回文。回文即正反序相同。如“abba”是回文,而“abab”不是回文。2、基本要求(1)数据从键盘读入;(2)输出要判断的字符串; (3)利用栈的基本操作对给定的字符串判断其是否是回文,若是则输出“Yes”,否则输出“No”。3、代码附录#include #include

2、 #include #include #define STACK_INIT_SIZE 100#define STACKINCREMENT 10# define MAXQSIZE 100# define OK 1# define ERROR 0typedef char QElemType;typedef char SElemType ;typedef struct SqStackSElemType *base;/在栈构造之前和销毁之后,base的值为NULLSElemType *top;/栈顶指针int stacksize;/当前已分配的存储空间,以元素为单位SqStack;typedef st

3、ruct SqQueue/构造队链 QElemType *base; int front; int rear;SqQueue;int InitStack(SqStack &S) /构造一个空栈S S.base=(SElemType *)malloc(STACK_INIT_SIZE * sizeof(SElemType);if(!S.base)/存储分配失败 cout存储分配失败!endl; return (0);S.top =S.base ;S.stacksize =STACK_INIT_SIZE;cout已成功建立空栈S!S.stacksize) /栈满追加存储空间 S.base=(SEle

4、mType *)realloc(S.base,(S.stacksize+STACKINCREMENT*sizeof(SElemType); if(!S.base) cout存储空间已满!endl; return(0); S.top=S.base+S.stacksize; S.stacksize+=STACKINCREMENT; *S.top+=e; return (1);int StackEmpty(SqStack &S) /若栈空返回OK否则返回error if(S.top=S.base) return(1); else return(0);int Pop(SqStack &S,SElemT

5、ype &e) /若栈不空则删除栈顶元素用e返回其值并返回OK否则返回error if(S.top=S.base) coutUnderflow!endl; return (0);e=*-S.top; return(1);int InitQueue(SqQueue &Q)/构造一个空队链Q Q.base=(QElemType *)malloc(MAXQSIZE*sizeof(QElemType); if(!Q.base) coutendl存储分配失败 ! ;/存储分配失败return (ERROR); Q.front=Q.rear=0;cout已成功建立队链Q!endl; return (OK)

6、; int EnQueue(SqQueue &Q,QElemType e)/插入元素e为Q的新的队尾元素 if(Q.rear+1)%MAXQSIZE=Q.front) coutErrer ! The SqQeueu is full ! ;return (ERROR); /存储分配失败 Q.baseQ.rear=e; Q.rear=(Q.rear+1)%MAXQSIZE; return (OK); int DeQueue(SqQueue &Q,QElemType &e)/若栈不空则删除Q的队头元素用e返回其值并返回OK否则返回error if(Q.front=Q.rear) coutendlEr

7、rer ! Its empty!;return (ERROR); e=Q.baseQ.front; Q.front=(Q.front+1)%MAXQSIZE; return (e); int Palindrome_Test()/判别输入的字符串是否回文序列,是则返回1,否则返回0 SqStack S; SqQueue Q; char a,b,c; InitStack(S);InitQueue(Q); cout请用键盘输入字符串并以结尾: endl; while(c=getchar()!=) Push(S,c);EnQueue(Q,c);/同时使用栈和队列两种结构 while(!StackEmpty(S) Pop(S,a);DeQueue(Q,b); if(a!=b) return ERROR; return OK; void main() cout回文判断程序endl=endl; if(Palindrome_Test() cout.该字符串是回文.!endl; else cout.该字符串不

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论