全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

C语言用栈和队列实现的回文检测功能示例

本文实例讲述了C语言用栈和队列实现的回文功能。分享给大家供大家参考,具体如下:

#include<stdio.h>
#include<malloc.h>//内存分配头文件
#include<math.h>//在math.h中已定义OVERFLOW的值为3
#define SIZE 100
#define STACKINCREMENT 10
#define OK 1
#define ERROR 0
#define TRUE 1
#define FALSE 0
typedef int Status;
typedef struct   //栈的结构体
{
  char a;
} SElemType;
typedef struct
{
  SElemType *base;
  SElemType *top;
  int stacksize;
} SqStack;
typedef struct //QNode //队列的结构体
{
  char b;
  struct QNode * next;
} QNode,*QueuePtr;
typedef struct // 链队列类型
{
  QueuePtr front;  // 队头指针
  QueuePtr rear;  // 队尾指针
} LinkQueue;
//定义全局变量
SqStack S;
SElemType e;
LinkQueue Q;
QueuePtr p;
char f;
//栈操作
Status InitStack(SqStack *S)
{
  S->base=(SElemType *)malloc(SIZE*sizeof(SElemType));
  if(!S->base) exit(OVERFLOW);
  S->top=S->base;
  S->stacksize=SIZE;
  return OK;
}
Status Push(SqStack *S,SElemType e)
{
  if(S->top-S->base>=S->stacksize)
  {
    S->base=(SElemType *)malloc((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 Stackempty(SqStack S)//栈是否为空
{
  if(S.top==S.base)
    return TRUE;
  else
    return FALSE;
}
Status Pop(SqStack *S,SElemType *e)
{
  if(S->top==S->base) return ERROR;
  *e=*--S->top;
  return OK;
}
Status StackLength(SqStack S)//求栈的长度
{
  return (S.top-S.base);
}
//队列操作
Status InitQueue(LinkQueue *Q)
{
  Q->front=(QueuePtr)malloc(sizeof(QNode));
  Q->rear=Q->front;
  if(!Q->front) exit(OVERFLOW);
  Q->front->next=NULL;
  return OK;
}
Status EnQueue(LinkQueue *Q,char f)
{
  p=(QueuePtr)malloc(sizeof(QNode));
  if(!p) exit(OVERFLOW);
  p->b=f;
  p->next=NULL;
  Q->rear->next=p;
  Q->rear=p;
  return OK;
}
Status DeQueue(LinkQueue *Q,char *f)
{
  if(Q->front==Q->rear) return ERROR;
  p=Q->front->next;
  *f=p->b;
  Q->front->next=p->next;
  if(Q->rear==p)
    Q->rear=Q->front;
  free(p);
  return OK;
}
Status QueueLength(LinkQueue Q)
{
  int i=0;
  p=Q.front;
  while(Q.rear!=p)
  {
    i++;
    p=p->next;
  }
  return i;
}
Status QueueEmpty(LinkQueue Q)
{
  if(Q.front==Q.rear)
    return TRUE;
  else
    return FALSE;
}
void main()
{
  int i,m;
  char n,a[20];
  InitStack(&S);
  InitQueue(&Q);
  gets(a);
  for(i=0; a[i]!='&'; i++) ///////////    &前的数据进栈
  {
    e.a=a[i];
    Push(&S,e);
  }
  for(i=i+1; a[i]!='\0'; i++) //////////   ‘ &'后的数据进入队列
    EnQueue(&Q,a[i]);
  if( StackLength(S)!=QueueLength(Q))    /////栈和队列的数据个数不一样
    printf("NO!!!!!!!!!!!!!!!!!!!!!!!!!!!!");
  else
    while(!Stackempty(S)&&!QueueEmpty(Q))///////栈和队列里还有数据
    {
      Pop(&S,&e);
      m=e.a;
      DeQueue(&Q,&f);
      n=f;
      if(m!=n)
      {
        printf("NO!!!!!!!!!!!!!!!!!!!!!!");
        break;
      }
    }
  if(m==n&&Stackempty(S)&&QueueEmpty(Q))
    printf("YES!!!!!!!!!!!!!!!!!!!!!!");
}

运行结果:

希望本文所述对大家C语言程序设计有所帮助。


# C语言  #   # 队列  # 回文检测  # C语言 浅谈栈与队列的定义与操作  # C语言数据结构进阶之栈和队列的实现  # C语言编程数据结构栈与队列的全面讲解示例教程  # C语言编程数据结构的栈和队列  # C语言中栈和队列实现表达式求值的实例  # C语言 表、栈和队列详解及实例代码  # 深入浅析C语言中堆栈和队列  # C语言超详细讲解栈与队列实现实例  # 给大家  # 所述  # 值为  # 为空  # 头文件  # 全局变量  # 讲述了  # STACKINCREMENT  # amp  # define  # SIZE  # ERROR  # int  # Status  # struct  # TRUE  # FALSE  # typedef  # OVERFLOW  # class 


相关文章: 如何通过宝塔面板实现本地网站访问?  如何在Windows环境下新建FTP站点并设置权限?  宝盒自助建站智能生成技巧:SEO优化与关键词设置指南  太原网站制作公司有哪些,网约车营运证查询官网?  ui设计制作网站有哪些,手机UI设计网址吗?  建站之星logo尺寸如何设置最合适?  桂林网站制作公司有哪些,桂林马拉松怎么报名?  建站之星免费版是否永久可用?  定制建站方案优化指南:企业官网开发与建站费用解析  制作网站外包平台,自动化接单网站有哪些?  企业微网站怎么做,公司网站和公众号有什么区别?  建站主机是否等同于虚拟主机?  专业企业网站设计制作公司,如何理解商贸企业的统一配送和分销网络建设?  建站之星导航菜单设置与功能模块配置全攻略  建站之星导航如何优化提升用户体验?  零服务器AI建站解决方案:快速部署与云端平台低成本实践  如何基于云服务器快速搭建个人网站?  建站主机是否属于云主机类型?  黑客如何利用漏洞与弱口令入侵网站服务器?  手机网站制作与建设方案,手机网站如何建设?  宝塔面板如何快速创建新站点?  建站主机选择指南:服务器配置与SEO优化实战技巧  如何通过老薛主机一键快速建站?  贸易公司网站制作流程,出口贸易网站设计怎么做?  已有域名建站全流程解析:网站搭建步骤与建站工具选择  网站制作大概多少钱一个,做一个平台网站大概多少钱?  小建面朝正北,A点实际方位是否存在偏差?  宝塔建站后网页无法访问如何解决?  详解ASP.NET 生成二维码实例(采用ThoughtWorks.QRCode和QrCode.Net两种方式)  如何在局域网内绑定自建网站域名?  魔方云NAT建站如何实现端口转发?  如何获取开源自助建站系统免费下载链接?  如何通过虚拟主机快速完成网站搭建?  广州顶尖建站服务:企业官网建设与SEO优化一体化方案  如何通过虚拟主机快速搭建个人网站?  建站主机选购指南:核心配置优化与品牌推荐方案  c# Task.Yield 的作用是什么 它和Task.Delay(1)有区别吗  如何在香港免费服务器上快速搭建网站?  如何设置并定期更换建站之星安全管理员密码?  建站主机如何选?性能与价格怎样平衡?  网站建设制作、微信公众号,公明人民医院怎么在网上预约?  如何做网站制作流程,*游戏网站怎么搭建?  如何在宝塔面板中修改默认建站目录?  如何快速打造个性化非模板自助建站?  如何选择服务器才能高效搭建专属网站?  建站主机如何选?高性价比方案全解析  如何在IIS中新建站点并解决端口绑定冲突?  如何在宝塔面板中创建新站点?  哪家制作企业网站好,开办像阿里巴巴那样的网络公司和网站要怎么做?  公司门户网站制作公司有哪些,怎样使用wordpress制作一个企业网站? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。