关于一个用栈来检查表达式的括号匹不匹配的代码,其中表达式中括号有三种:(),[]和{}

songsong2008 2004-11-15 07:11:23
#include <stdio.h>
#include <stdlib.h>
#define STACK_INIT_SIZE 200
typedef struct
{
char * base;
char * top;
}stack;

int Init(stack *s)
{s->base=(char *)malloc(STACK_INIT_SIZE*sizeof(char));
if(!s->base) return 0;
s->top=s->base;
return 1;
}
void Destroy(stack *s)
{free(s->base);
s->base=NULL;
s->top=NULL;
}
void Push(stack *s,char c)
{
*s->top++=c;
}

int pop(stack *s,char *c)
{if(s->top==s->base) return 0;
*c=*--s->top;
return 1;
}
/*---------------------------------------------------------------*/
int Check(stack *s,char *expr)
{int i;
char c[1];
for(i=0;expr[i]!='\0';i++)
{if(expr[i]=='{'||expr[i]=='['||expr[i]=='(') Push(s,expr[i]);
if(expr[i]=='}'||expr[i]==']'||expr[i]==')')
{
if(pop(s,c)==0) return 0;/*栈空,表达式有错*/
else
{if(expr[i]==')')
{
if(c[0]!='(') return 0;
}
else
if(expr[i]-c[0]!=2) return 0;/*'{'和'}'式'['和']'的ASCII码差2*/
}
}
}
if(s->base!=s->top)
return 0;
return 1;
}
/*-------------------------------------------------------------*/
void main()
{
char expr[100];
stack *s;
printf("input the expression\n");
scanf("%s",expr);
if(!Init(s))//第一句warning
exit(0);
if(Check(s,expr))//第二句warning
printf("right\n");
else
printf("wrong\n");
Destroy(s);//第三句warning
}
-----------------------------
程序运行正确,不过有三个warning(即main中用到s的地方都有一个相同的warning:"possible use "s" before definition")这是什么原因呢?我不是已经在stack *s这一句定义s吗?
...全文
432 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
BlackEagle_ 2004-11-15
  • 打赏
  • 举报
回复
在stack *s;后面加一句:
s = null;
kobefly 2004-11-15
  • 打赏
  • 举报
回复
严奶奶数据结构书上的啊
有部分伪代码
sharkhuang 2004-11-15
  • 打赏
  • 举报
回复
压栈匹配扩府经典算法哈
liujingfu123 2004-11-15
  • 打赏
  • 举报
回复
在main()中,你的s 是一个指针,你只是声明了,但没分配空间给它(没初始化),而是调用函数给它初始化的。
内容概要:本文研究了基于瞬态三角哈里斯鹰算法(TTHHO)求解带时间窗约束的骑手外卖配送路径规划问题,旨在优化配送效率与服务质量。该算法通过引入瞬态三角搜索机制,增强了传统哈里斯鹰优化算法的全局探索能力和收敛速度,有效解决了路径规划中的组合优化难题。研究建立了符合实际配送场景的数学模型,综合考虑了骑手行驶时间、客户时间窗限制、订单优先级等因素,利用Matlab进行算法实现与仿真实验。结果表明,TTHHO算法在降低总配送里程、提高准时送达率方面优于传统智能优化算法,具备较强的实用性和鲁棒性。; 适合人群:具备一定运筹优化、智能算法基础,从事物流调度、城市配送、外卖平台运营等相关领域研究或开发工作的科研人员及工程师,尤其适合研究生及以上学历或有1-3年相关工作经验的技术人员; 使用场景及目标:①解决城市外卖配送中多订单、多客户、带时间窗的路径优化问题;②提升配送效率、降低运营成本、改善用户体验;③为智能交通系统、即时配送平台提供算法支持与决策参考; 阅读建议:建议读者结合Matlab代码深入理解算法实现细节,重点关注TTHHO算法的搜索机制设计与参数设置,并通过调整测试案例规模和约束条件进行对比实验,以充分掌握其性能特点与适用边界。
内容概要:本文针对永磁同步电机(PMSM)发电控制系统,研究并实现了将先进PID控制算法——自抗扰控制(ADRC)及其核心组件跟踪微分器(TD)和扩张状态观测器(ESO)——集成到传统控制框架中的方法。通过Matlab/Simulink搭建详细的系统仿真模型,深入探讨了ADRC相较于传统PID在应对系统非线性、外部扰动和参数不确定性方面的显著优势。研究详细阐述了TD对设定值进行平滑规划以减少超调、ESO实时估计并补偿内外部总扰动的核心机理,最终通过仿真实验验证了ADRC能大幅提升系统的动态响应速度、抗干扰能力和运行稳定性。; 适合人群:具备自动控制原理、电机学基础和Matlab/Simulink仿真经验的电气工程、自动化及相关专业的高校师生、研究人员及从事电机控制、新能源发电领域的工程技术人员。; 使用场景及目标:① 深入理解ADRC、TD、ESO等先进控制算法的核心思想与工作原理;② 学习如何在Matlab/Simulink中构建永磁同步电机的发电控制仿真模型;③ 掌握将ADRC算法应用于电机控制的具体实现方法,并通过仿真对比分析其相对于传统PID的性能优势;④ 为新能源发电系统、高性能电机驱动等领域的控制策略优化提供技术参考和实践范例。; 阅读建议:在阅读过程中,应结合Matlab代码和Simulink模型进行实践操作,重点分析TD和ESO各参数对系统性能的影响,并尝试修改控制策略和仿真条件以加深理解,从而真正掌握先进控制算法的设计精髓与应用技巧。

70,038

社区成员

发帖
与我相关
我的任务
社区描述
C语言相关问题讨论
社区管理员
  • C语言
  • 花神庙码农
  • 架构师李肯
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧