#
include
<stdio.h>
#
include
<stdlib.h>
#define STACK_INIT_SIZE
100
#define STACKINCREMENT
10
#define TRUE
1
#define FALSE
0
#define OK
0
#define OVERFLOW -
1
#define ERROR -
2
typedef char ElemType;
typedef
int
Status;
typedef struct{
ElemType *base;
ElemType *top;
int
stacksize;
}SqStack;
typedef struct QNode{
ElemType data;
struct QNode *next;
}QNode, *QueuePtr;
typedef struct{
QueuePtr front;
QueuePtr rear;
}LinkQueue;
Status InitStack(SqStack &S){
S.base = (ElemType*)malloc(STACK_INIT_SIZE * sizeof(ElemType));
if
(!S.base) exit(OVERFLOW);
S.top = S.base;
S.stacksize = STACK_INIT_SIZE;
return
OK;
}
Status Push(SqStack &S, ElemType e){
if
((S.top - S.base) >= S.stacksize){
S.base = (ElemType*)realloc(S.base, (STACK_INIT_SIZE + STACKINCREMENT) * sizeof(ElemType));
if
(!S.base) exit(OVERFLOW);
S.top = S.base + S.stacksize;
S.stacksize += STACKINCREMENT;
}
*(S.top++) = e;
return
OK;
}
Status Pop(SqStack &S, ElemType &e){
if
(S.top == S.base)
return
ERROR;
e = *(--S.top);
return
OK;
}
int
StackEmpty(SqStack S){
if
(S.top == S.base)
return
TRUE;
return
FALSE;
}
Status InitQueue(LinkQueue &Q){
Q.front = Q.rear = (QueuePtr)malloc(sizeof(QNode));
if
(!Q.front) exit(OVERFLOW);
Q.front->next = NULL;
return
OK;
}
Status EnQueue(LinkQueue &Q, ElemType e){
QueuePtr p;
p = (QueuePtr)malloc(sizeof(QNode));
if
(!p) exit(OVERFLOW);
p->data = e;
p->next = NULL;
Q.rear->next = p;
Q.rear = p;
return
OK;
}
Status DeQueue(LinkQueue &Q, ElemType &e){
QueuePtr p;
if
(Q.front == Q.rear)
return
ERROR;
p = Q.front->next;
e = p->data;
Q.front->next = p->next;
if
(Q.rear == p) Q.rear = Q.front;
free(p);
return
OK;
}
int
QueueEmpty(LinkQueue Q){
if
(Q.front == Q.rear)
return
TRUE;
return
FALSE;
}
void
main(){
char *p =
new
char;
char *str =
new
char;
int
flag =
1
;
ElemType e1, e2;
LinkQueue q;
InitQueue(q);
SqStack s;
InitStack(s);
printf(
"输入一段字符串\n"
);
scanf(
"%s"
, p);
str = p;
printf(
"\n进行进栈,进队列操作\n"
);
while
(*p){
Push(s, *p);
EnQueue(q, *p);
printf(
"压入的是%c\n"
, *p);
p++;
}
printf(
"\n判断是否回文\n"
);
while
(!StackEmpty(s)){
Pop(s, e1);
DeQueue(q, e2);
printf(
"栈值:%c, 队列值:%c\n"
, e1, e2);
if
(e1 != e2){
flag =
0
;
break
;
}
}
if
(flag ==
1
)
printf(
"%s是回文\n"
, str);
else
printf(
"%s不是回文\n"
, str);
}