第一范文网 - 专业文章范例文档资料分享平台

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

来源:用户分享 时间:2025/6/17 2:54:18 本文由loading 分享 下载这篇文档手机版
说明:文章内容仅供预览,部分内容可能不全,需要完整文档或者需要复制内容,请下载word后使用。下载word有问题请添加微信号:xxxxxxx或QQ:xxxxxx 处理(尽可能给您提供完整文档),感谢您的支持与谅解。

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文档下载到电脑,方便复制、编辑、收藏和打印
本文链接:https://www.diyifanwen.net/c5sanw1kf7d036aw5ujwp_3.html(转载请注明文章来源)
热门推荐
Copyright © 2012-2023 第一范文网 版权所有 免责声明 | 联系我们
声明 :本网站尊重并保护知识产权,根据《信息网络传播权保护条例》,如果我们转载的作品侵犯了您的权利,请在一个月内通知我们,我们会及时删除。
客服QQ:xxxxxx 邮箱:xxxxxx@qq.com
渝ICP备2023013149号
Top