| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 623 人关注过本帖
标题:只有这么点分了,关于DebugAssertionFailed的问题,请前辈们抽空看看
只看楼主 加入收藏
icanbestrong
Rank: 3Rank: 3
等 级:论坛游侠
帖 子:100
专家分:138
注 册:2013-3-13
结帖率:50%
收藏
已结贴  问题点数:10 回复次数:3 
只有这么点分了,关于DebugAssertionFailed的问题,请前辈们抽空看看
#include<stdio.h>
#include<malloc.h>
#include<stdlib.h>
#include <string>
#define STACK_INIT_SIZE 100
#define STACKINCREMENT 10
typedef struct{
char *base,*top;
int stacksize;
}SqStack;
int InitStack(SqStack S){
S.base=(char *)malloc(STACK_INIT_SIZE*sizeof(char));
if(!S.base) exit(0);
S.top=S.base;
S.stacksize=STACK_INIT_SIZE;
return 1;
}
char GetTop(SqStack S,char e){
e=*(S.top-1);
return e;
}
int Push(SqStack S,char e){
if(S.top-S.base>=S.stacksize){
S.base=(char*)realloc(S.base,(S.stacksize+STACKINCREMENT)*sizeof(char));
if(!S.base) exit(-1);
S.top=S.base+S.stacksize;
S.stacksize+=STACKINCREMENT;
}
*S.top++=e;
return 1;
}
char Pop(SqStack S,char e){
e=*--S.top;
return e;
}
int In(char c){
if(c=='+'||c=='-'||c=='*'||c=='/'||c=='('||c==')')
return 1;
return 0;
}
char Precede(char e,char c){
if(e=='+'&&c=='+'||c=='-'||c==')'||c=='#')
return '>';
if(e=='+'&&c=='*'||c=='/'||c=='(')
return '<';
if(e=='-'&&c=='+'||c=='-'||c==')'||c=='#')
return '>';
if(e=='-'&&c=='*'||c=='/'||c=='(')
return '<';
if(e=='*'&&c=='+'||c=='-'||c=='*'||c=='/'||c==')'||c=='#')
return '>';
if(e=='*'&&c=='(')
return '<';
if(e=='/'&&c=='+'||c=='-'||c=='*'||c=='/'||c==')'||c=='#')
return '>';
if(e=='/'&&c=='(')
return '<';
if(e=='('&&c=='+'||c=='-'||c=='*'||c=='/'||c=='(')
return '<';
if(e=='('&&c==')')
return '=';
if(e==')'&&c=='+'||c=='-'||c=='*'||c=='/'||c==')'||c=='#')
return '>';
if(e=='#'&&c=='+'||c=='-'||c=='*'||c=='/'||c=='(')
return '<';
if(e=='#'&&e=='#')
return '=';
}
char Operate(char a,char theta,char b){
float k;
a=(float)a;
b=(float)b;
if(theta=='+')
k=a+b;
if(theta=='-')
k=a-b;
if(theta=='*')
k=a*b;
if(theta=='/')
k=a/b;
k=(char)k;
return k;
}
char Evaluate(char *s){
SqStack OPTR,OPND;
char c,k,a,b;
InitStack(OPTR);
Push(OPTR,'#');
InitStack(OPND);
c=getchar();
while(c!='#'||GetTop(OPTR,k)!='#'){
    if(!In(k))
    {Push(OPND,k);
c=getchar();
}
    else
{GetTop(OPTR,k);
switch(Precede(k,c)){
case'<':
Push(OPTR,c);
c=getchar();
break;
case'=':
Pop(OPTR,k);
c=getchar();
break;
case'>':
Pop(OPTR,k);
Pop(OPND,a);
Pop(OPND,b);
Push(OPND,Operate(a,k,b));
break;
}
}
}
return GetTop(OPND,a);
}
int main(){
char s[20],c;
gets(s);
c=Evaluate(s);
printf("%c",c);
return 0;
}
程序编译通过了,但当输入完事时老显示debugassertionfailed,请教一下该怎莫修改,程序的功能是输入一个数字表达式,计算值,
搜索更多相关主题的帖子: include return 
2013-10-28 19:41
那个人
Rank: 2
等 级:论坛游民
帖 子:20
专家分:32
注 册:2013-1-25
收藏
得分:5 
学渣飘过,表示看不懂。。。。。
2013-10-28 20:09
pauljames
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
等 级:千里冰封
威 望:9
帖 子:1555
专家分:10000
注 册:2011-5-8
收藏
得分:5 
找数据结构的书,栈的应用,表达式求值

经常不在线不能及时回复短消息,如有c/单片机/运动控制/数据采集等方面的项目难题可加qq1921826084。
2013-10-28 21:02
icanbestrong
Rank: 3Rank: 3
等 级:论坛游侠
帖 子:100
专家分:138
注 册:2013-3-13
收藏
得分:0 
我就是把数据结构中的算法代码化了,结果提示说是validheappoint,大概是野指针的意思吧
2013-10-28 21:06
快速回复:只有这么点分了,关于DebugAssertionFailed的问题,请前辈们抽空看看
数据加载中...
 
   



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

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