回文函数
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
#include
#include
#include
#include
#include
#define STACK_INIT_SIZE 100//存储空间初始分配量
#define OVERFLOW -1
#define OK 1
#define STACKINCREMENT 10//存储空间分配增量
#define ERROR 0
#define TRUE 1
#define FALSE 0
#define MAXQSIZE 100
typedef char QElemType;
typedef char SElemType;
typedef int Status;
/*********************************************************
*
* 栈类型及其基本操作
*
**********************************************************/ typedef struct{//顺序栈的定义
SElemType *base;
SElemType *top;
int stacksize;
}SqStack;
Status InitStack(SqStack &S){//构造一个空栈S
S.base=(SElemType *)malloc(STACK_INIT_SIZE*sizeof(SElemType));
if(!S.base)exit(OVERFLOW);//存储分配失败
S.top=S.base;
S.stacksize=STACK_INIT_SIZE;
return OK;
}
Status Push(SqStack &S,SElemType e){
//插入元素e为新世界的栈顶元素
if(S.top-S.base>=S.stacksize){//栈满,追加存储空间
S.base=(SElemType
*)realloc(S.base,(S.stacksize+STACKINCREMENT)*sizeof(SElemType));
if(!S.base)exit(OVERFLOW);//存储分配失败
S.top=S.base+S.stacksize;
S.stacksize+=STACKINCREMENT;
}
*S.top++=e;
return OK;
}
Status Pop(SqStack &S,SElemType &e){
//若栈不空,则删除S的栈顶元素,用e反回其值,并返回OK;否则返回ERROR if(S.top==S.base)return ERROR;
e=*--S.top;
return OK;
}
Status StackEmpty(SqStack S){//判断栈S是否已空
if(S.top==S.base)
return TRUE;
else return FALSE;
}
/*********************************************************
*
* 队列类型及其基本操作
*
**********************************************************/
typedef struct{
QElemType *base;
int front;
int rear;
}SqQueue;
Status InitQueue(SqQueue &Q){
Q.base=(QElemType *)malloc(MAXQSIZE *sizeof(QElemType));
if(!Q.base) exit(0);
Q.front=Q.rear=0;
return 1;
}
Status EnQueue(SqQueue &Q,QElemType e){
if((Q.rear+1)%MAXQSIZE==Q.front)return 0;
Q.base[Q.rear]=e;
Q.rear=(Q.rear+1)%MAXQSIZE;
return 1;
}
Status DeQueue(SqQueue &Q,QElemType &e){
if(Q.front==Q.rear)return 0;
e=Q.base[Q.front];
Q.front=(Q.front+1)%MAXQSIZE;
return 1;
}