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

为什么出现内存不可read

[复制链接]
发表于 2009-11-5 00:29:48 | 显示全部楼层 |阅读模式 IP:江苏扬州
这是个简单的某个文法的LL(1),可对 i+i*i# 这类匹配
为什么我输入有'i'的时候就回出现什么内存不可读


#include<string.h>
#include<stdlib.h>
#include<iostream.h>
char a[]={'E','e','T','t','F','A','M'};
char b[]={'i','+','-','*','/','(',')','#'};
char *f[7][8]={{"Te","0","0","0","0","Te","0","0"},{"0","ATe","ATe","0","0","0","k","k"},
{"Ft","0","0","0","0","Ft","0","0"},{"0","k","k","MFt","MFt","0","k","k"},
{"i","0","0","0","0","(E)","0","0"},{"0","+","-","0","0","0","0","0"},
{"0","0","0","*","/","0","0","0"}};
struct stack{
char s[20];
int t;};
typedef struct stack *pseqstack;
pseqstack create(void)
{ pseqstack pastack;
pastack=(pseqstack)malloc(sizeof(struct stack));
if(pastack==NULL)
cout<<"out of space"<<endl;
else pastack->t=-1;
return(pastack);
}

void push(pseqstack pastack,char x)
{ pastack->t=pastack->t+1;
int i=0;
i=pastack->t;
pastack->s[i]=x;
}
void pop(pseqstack pastack)
{if(pastack->t==-1)
cout<<"underflow"<<endl;
else
pastack->t=pastack->t-1;
}
char top(pseqstack pastack)
{return(pastack->s[pastack->t]);
}

void macth(pseqstack pastack,char *p)
{ int j=0,m=0,n=0,q=0;
char tp;
char temp[10];

for(;;)
{tp=top(pastack);
if(tp=='#')
{if(p[j]=='#')
cout<<"macth"<<endl;
else
cout<<"error"<<endl;
break;
}
if(tp=='i'||tp=='+'||tp=='-'||tp=='*'||tp=='/'||tp=='('||tp==')')
{

if(tp==p[j])
{pop(pastack);
j++;
continue;}
else
{cout<<"error"<<endl;
break;
}
}
for(m=0;m<7;m++)
{if(a[m]==tp)
break;}
for(n=0;n<8;n++)
{if(b[n]==p[j])
break;}
strcpy(temp,f[m][n]);
if(strcmp(temp,"k")==0)

{pop(pastack);
continue;
}
if(strcmp(temp,"0")==0)
{cout<<"error"<<endl;
break;
}
else
{for(n=0;temp[n]!='\0';n++)
{
q=q+1;
}
for(n=q-1;n>=0;n--)
{
push(pastack,temp[n]);
}
}

}

}
void main()
{ char ru[10];
char j;

pseqstack pk=create();

j='#';
push(pk,j);
j='E';
push(pk,j);
cout<<"shu ru zifu chuan: ";
cin>>ru;
macth(pk,ru);
}
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2024-10-1 07:41 , Processed in 0.168717 second(s), 13 queries , Gzip On, MemCache On.

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

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