找回密码
 注册
搜索
热搜: 回贴
  • 前程无忧官网首页 有什么好的平台可以
  • 最新的销售平台 互联网营销的平台有哪
  • 制作网页的基本流程 网页制作和网页设
  • 【帝国CMS】输出带序号的列表(数字排
  • 网站建设公司 三一,中联,极东泵车的
  • 织梦 建站 织梦网站模版后台怎么更改
  • 云服务官网 哪些网站有免费的简历模板
  • 如何建网站要什么条件 建网站要用什么
  • 吉林市移动公司电话 吉林省退休人员网
  • 设计类毕业论文 网站设计与实现毕业论
查看: 2000|回复: 3

[求助]我的程序错误找不到

[复制链接]
发表于 2009-11-4 01:22:05 | 显示全部楼层 |阅读模式 IP:江苏扬州
//头文件a.h
#include <stdlib.h>
#include <iostream.h>
#define max 10
typedef struct
{
char * base;
char * top;
int stacksize;
}Sqstack;
int Initstack(Sqstack &s)
{
s.base=(char *) malloc(max*sizeof(char));
if(!s.base) exit(0);
s.top=s.base;
s.stacksize=max;
return 1;
}
int Push(Sqstack &s,char e)
{
if(s.top-s.base>=s.stacksize)
{
s.base=(char *)realloc(s.base,(s.stacksize+max)*sizeof(char));
if(!s.base) exit(0);
s.top=s.base+s.stacksize;
s.stacksize+=max;
}
*s.top++=e;
return 1;
}
int Pop(Sqstack&s)
{
if(s.top==s.base)
return 0;
else
--s.top;
return 1;
}
char Gettop(Sqstack &s)
{
if(s.top==s.base)
return 0;
else
return *s.top;
}
void match (char st[ ])
{
int i=0;
char ch;
int valid=1;
Sqstack s;
Initstack(s);
ch=st[i];
while(valid&&i<6)
{
switch(ch)
{
case '{':
case '[':
case '(':
Push(s,ch);
break;
case '}':
if(Gettop(s)=='{')
Pop(s);
else valid=0;
break;
case ']':
if(Gettop(s)=='[')
Pop(s);
else valid=0;
break;
case ')':
if(Gettop(s)=='(')
Pop(s);
else valid=0;
break;
}
ch=st[++i];
}
if (valid)
cout<<"括号匹配"<<endl;
else
cout<<"括号不匹配"<<endl;
}
//主函数
#include <iostream.h>
#include "a.h"
void main()
{
char s[]={'[','(','{','}',')',']'};
match(s);
}
帮帮我看下程序其中的错误.
发表于 2009-11-4 01:22:06 | 显示全部楼层 IP:江苏扬州
你能不能把头文件a.h发上来,这样高手们才能帮你看下啊,不然不容易看啊
回复

使用道具 举报

发表于 2009-11-4 01:22:07 | 显示全部楼层 IP:江苏扬州
你的栈设计的有问题

int Pop(Sqstack&s)
{
if(s.top==s.base)
return 0;
else
--s.top;
return 1;
}
我猜测,你想让top指向最后一个元素之后,如果真是这样的话Push里的
*s.top++=e;
这一句,得改成
*(++s.top)=e;

另外,你只分配内存而不释放,可不是好习惯

(C++标准库里有stack模板,我猜你是从C转到C++的吧?多用标准库提供的工具,比自己写有好处)
回复

使用道具 举报

发表于 2009-11-4 01:22:08 | 显示全部楼层 IP:江苏扬州
还是先让他写吧
都要有这个阶段锻炼
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|小黑屋|最新主题|手机版|微赢网络技术论坛 ( 苏ICP备08020429号 )

GMT+8, 2024-10-1 01:31 , Processed in 0.177163 second(s), 12 queries , Gzip On, MemCache On.

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表