| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 488 人关注过本帖
标题:[求助]我的程序错误找不到
只看楼主 加入收藏
shumyun
Rank: 1
等 级:新手上路
帖 子:13
专家分:0
注 册:2006-3-26
收藏
 问题点数:0 回复次数:3 
[求助]我的程序错误找不到

//头文件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);
}

帮帮我看下程序其中的错误.

2006-10-22 12:03
xiaori
Rank: 1
等 级:新手上路
帖 子:25
专家分:0
注 册:2006-11-22
收藏
得分:0 
你能不能把头文件a.h发上来,这样高手们才能帮你看下啊,不然不容易看啊

希望和大家交朋友,相互帮助,共同提高!
2006-11-28 23:19
litcatyx
Rank: 1
等 级:新手上路
威 望:1
帖 子:151
专家分:0
注 册:2006-10-27
收藏
得分:0 
你的栈设计的有问题

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++的吧?多用标准库提供的工具,比自己写有好处)



2006-11-29 20:39
song4
Rank: 7Rank: 7Rank: 7
等 级:贵宾
威 望:38
帖 子:1533
专家分:4
注 册:2006-3-25
收藏
得分:0 
还是先让他写吧
都要有这个阶段锻炼

嵌入式 ARM 单片机 驱动 RT操作系统 J2ME LINUX  Symbian C C++ 数据结构 JAVA Oracle 设计模式 软件工程 JSP
2006-11-29 21:37
快速回复:[求助]我的程序错误找不到
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.016961 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved