标题:[求助]判断表达式中左右括号是否匹配,运行结果不对啊那位大哥帮看下,谢谢
只看楼主
柒兲
Rank: 1
等 级:新手上路
威 望:1
帖 子:126
专家分:0
注 册:2007-9-26
 问题点数:0 回复次数:10 
[求助]判断表达式中左右括号是否匹配,运行结果不对啊那位大哥帮看下,谢谢

#include <stdio.h>
#include <stdlib.h>
#include <malloc.h>

typedef struct stack
{
char data;
struct stack *next;
}ListStack;

ListStack *Init_Stack()
{
ListStack *top;
top=(ListStack *)malloc(sizeof(ListStack));
top->data='#';
top->next=NULL;
return top;
}/*Init_Stack*/

ListStack * Push_Stack(ListStack *top,char c)
{
ListStack *p;
p=(ListStack *)malloc(sizeof(ListStack));
p->data=c;
p->next=top->next;
top->next=p;
top=top->next;
return top;
}/*Push_Stack*/

ListStack * Pop_Stack(ListStack *top)
{
char c;
ListStack *p;
if(top->next==NULL)
return 0;
c=p->data;
top->next=p->next;
free(p);
return top;
}/*Pop_Stack*/


void main()
{
char a[50];
char c;
int i;
printf("请输入你的表达式: ");
gets(a);
ListStack *stack;
stack=Init_Stack();
for(i=0;(c=a[i])!='\0';i++)
{
if(c=='(')
{
Push_Stack(stack,c);
continue;
}
if(c==')')
{
if(stack->next==NULL)
printf("缺少左括号\n");
else
Pop_Stack(stack);
}
}
if(stack->next!=NULL)
printf("缺少右号\n");
else
printf("正确\n");
}

[此贴子已经被作者于2007-10-13 18:36:41编辑过]

搜索更多相关主题的帖子: 括号 结果 判断 运行 表达 
2007-10-10 19:37
aipb2007
Rank: 8Rank: 8
来 自:CQU
等 级:贵宾
威 望:40
帖 子:2879
专家分:7
注 册:2007-3-18
得分:0 

你首先要搞清楚是 你的stack设计错了,还是后面判断括号匹配错了。

自己分块测试,很快可以定位的!


Fight  to win  or  die...
2007-10-11 11:17
missiyou
Rank: 5Rank: 5
等 级:贵宾
威 望:16
帖 子:531
专家分:218
注 册:2007-10-9
得分:0 
应该是出栈问题。那个、
这个返回是一个int 型,可是你返回是一个字符。
int Pop_Stack(ListStack *top)
{
char c;
c=NULL;这个C是什么呀
ListStack *p;
p=(ListStack *)malloc(sizeof(ListStack));这个也不用
p->data=c;这个不应该用
top->next=p->next;//p=top->next; top->next=top->next->next;c=p->data;

free(p);
return c;
}/*Pop_Stack*/
2007-10-11 19:12
柒兲
Rank: 1
等 级:新手上路
威 望:1
帖 子:126
专家分:0
注 册:2007-9-26
得分:0 

谢谢大家了`

2007-10-11 21:04
柒兲
Rank: 1
等 级:新手上路
威 望:1
帖 子:126
专家分:0
注 册:2007-9-26
得分:0 
回复:(aipb2007)你首先要搞清楚是 你的stack设计错...
我大概测了一下``!
是``进出栈都有问题样啊` ` 师兄帮个忙``这个` 进出栈要那么写啊`` 谢谢了哦

2007-10-11 22:36
aipb2007
Rank: 8Rank: 8
来 自:CQU
等 级:贵宾
威 望:40
帖 子:2879
专家分:7
注 册:2007-3-18
得分:0 
void Push_Stack(ListStack *top,char c)
{
ListStack *p;
p=(ListStack *)malloc(sizeof(ListStack));
p->data=c;
p->next=top->next;
top->next=p;
}/*Push_Stack*/

void Push_Stack(ListStack *&top,char c) //引用调用

Fight  to win  or  die...
2007-10-11 23:05
aipb2007
Rank: 8Rank: 8
来 自:CQU
等 级:贵宾
威 望:40
帖 子:2879
专家分:7
注 册:2007-3-18
得分:0 
出栈就有点乱了。

出栈没必要分配空间了。
思想就是:

用一个指针指向top(即要删除的接点)
link *old = top;
top = top->next; 更新top
删除old
free(old)

当然最先要把要返回的数据先保存,最后再返回

Fight  to win  or  die...
2007-10-11 23:09
柒兲
Rank: 1
等 级:新手上路
威 望:1
帖 子:126
专家分:0
注 册:2007-9-26
得分:0 
回复:(aipb2007)出栈就有点乱了。出栈没必要分配空...

谢了哦`
` 现在`进出栈没有问题了` 就是` 后面判断有问题了
不知道那里出错了哦``想了半天也没有弄出来哦`!


2007-10-13 18:31
小灵心
Rank: 1
等 级:新手上路
帖 子:107
专家分:0
注 册:2007-10-2
得分:0 

学会调试和使用断言,,,这个真的很重要。。。


2007-10-13 18:48
aipb2007
Rank: 8Rank: 8
来 自:CQU
等 级:贵宾
威 望:40
帖 子:2879
专家分:7
注 册:2007-3-18
得分:0 

做括号进栈,右括号出栈。
看上去没什么问题,自己好好调试下吧!

还有你的stack封装的不够好。

你单纯判断()有点大材小用,我记得这个题目是判断[](){}同时匹配。


Fight  to win  or  die...
2007-10-13 19:28



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-176508-1-1.html




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

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