数据结构 栈和队列基本操作

2026/1/27 6:37:38

top->next=q->next; free(q); }

//队列

typedef struct QNode { char data;

struct QNode *next; }QNode,*QueuePtr; typedef struct { QueuePtr front; QueuePtr rear; }LinkQueue;

//构造一个空队列 Q

void InitQueue(LinkQueue &Q) {

Q.rear=Q.front=(QueuePtr)malloc(sizeof(QNode)); Q.front->next=NULL; }

void EnQueue(LinkQueue &Q,char e) {

QNode *p;

p=(QueuePtr)malloc(sizeof(QNode)); p->data=e;

p->next=NULL; Q.rear->next=p; Q.rear=p; }

void DeQueue(LinkQueue &Q,char &e2) {

QNode *p;

p=Q.front->next; e2=p->data;

Q.front->next=p->next; if(Q.rear==p) Q.rear=Q.front; free(p);

}

//回文判断函数

int Huiwen(LinkStack &S,LinkQueue &Q) {

char e1,e2; while(1) { Pop(S,e1); DeQueue(Q,e2); if(S->next==NULL&&Q.front==Q.rear) { return 1; } if(e1!=e2) { return 0; } } }

void main() {

char e,e1,e2; LinkStack S; InitLinkStack(S); LinkQueue Q; InitQueue(Q);

printf(\请输入字符串:\\n\ while(1) { scanf(\ if(e=='\\n') break; Push(S,e); EnQueue(Q,e); }

/*

while(1)

}

{ Pop(S,e1); DeQueue(Q,e2); if(S->next==NULL&&Q.front==Q.rear) { printf(\字符串是回文字符串!\\n\ break; } if(e1!=e2) { printf(\字符串不是回文字符串!\\n\ break; } } */ int a;

a=Huiwen(S,Q); if(a==1) printf(\字符串是回文字符串!\\n\else if(a==0) printf(\字符串不是回文字符串!\\n\


数据结构 栈和队列基本操作.doc 将本文的Word文档下载到电脑
搜索更多关于: 数据结构 栈和队列基本操作 的文档
相关推荐
相关阅读
× 游客快捷下载通道(下载后可以自由复制和排版)

下载本文档需要支付 10

支付方式:

开通VIP包月会员 特价:29元/月

注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
微信:xuecool-com QQ:370150219