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

发布时间 - 2026-01-11 01:44:32    点击率:

本文实例讲述了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 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel如何实现数据导出到CSV文件_Laravel原生流式输出大数据量CSV【方案】  车管所网站制作流程,交警当场开简易程序处罚决定书,在交警网站查询不到怎么办?  Laravel如何使用Gate和Policy进行授权?(权限控制)  Laravel项目结构怎么组织_大型Laravel应用的最佳目录结构实践  Laravel的契約(Contracts)是什么_深入理解Laravel Contracts与依赖倒置  如何注册花生壳免费域名并搭建个人网站?  教你用AI润色文章,让你的文字表达更专业  ,在苏州找工作,上哪个网站比较好?  Laravel与Inertia.js怎么结合_使用Laravel和Inertia构建现代单页应用  javascript中闭包概念与用法深入理解  Linux虚拟化技术教程_KVMQEMU虚拟机安装与调优  PHP正则匹配日期和时间(时间戳转换)的实例代码  Laravel如何配置任务调度?(Cron Job示例)  C++用Dijkstra(迪杰斯特拉)算法求最短路径  香港服务器租用费用高吗?如何避免常见误区?  Laravel如何编写单元测试和功能测试?(PHPUnit示例)  Linux系统运维自动化项目教程_Ansible批量管理实战  如何在万网ECS上快速搭建专属网站?  5种Android数据存储方式汇总  Win11应用商店下载慢怎么办 Win11更改DNS提速下载【修复】  香港服务器建站指南:外贸独立站搭建与跨境电商配置流程  JS经典正则表达式笔试题汇总  极客网站有哪些,DoNews、36氪、爱范儿、虎嗅、雷锋网、极客公园这些互联网媒体网站有什么差异?  如何在云主机上快速搭建多站点网站?  Angular 表单中正确绑定输入值以确保提交与验证正常工作  Laravel怎么实现一对多关联查询_Laravel Eloquent模型关系定义与预加载【实战】  敲碗10年!Mac系列传将迎来「触控与联网」双革新  JavaScript如何实现音频处理_Web Audio API如何工作?  WEB开发之注册页面验证码倒计时代码的实现  移动端脚本框架Hammer.js  1688铺货到淘宝怎么操作 1688一键铺货到自己店铺详细步骤  如何快速搭建高效服务器建站系统?  悟空浏览器如何设置小说背景色_悟空浏览器背景色设置【方法】  Laravel如何使用.env文件管理环境变量?(最佳实践)  php读取心率传感器数据怎么弄_php获取max30100的心率值【指南】  Laravel的路由模型绑定怎么用_Laravel Route Model Binding简化控制器逻辑  Laravel怎么自定义错误页面_Laravel修改404和500页面模板  智能起名网站制作软件有哪些,制作logo的软件?  Python文件异常处理策略_健壮性说明【指导】  Laravel怎么实现前端Toast弹窗提示_Laravel Session闪存数据Flash传递给前端【方法】  Java垃圾回收器的方法和原理总结  浅述节点的创建及常见功能的实现  Thinkphp 中 distinct 的用法解析  如何在阿里云虚拟主机上快速搭建个人网站?  ,怎么在广州志愿者网站注册?  如何用搬瓦工VPS快速搭建个人网站?  利用vue写todolist单页应用  如何破解联通资金短缺导致的基站建设难题?  Python文件流缓冲机制_IO性能解析【教程】  如何快速上传建站程序避免常见错误?