数据结构课程设计(C语言版),编程时出现问题,总是提示类似syntax error : missing ')' before '&'的错
用C语言实现《数据结构课程设计——资料室管理的设计与实现》,用VC++6.0编译的时候总是提示类似这样的报错:(报错太长,但是都是这样的报错,只是摘录部分)reader....
用C语言实现《数据结构课程设计——资料室管理的设计与实现》,用VC++6.0编译的时候总是提示类似这样的报错:(报错太长,但是都是这样的报错,只是摘录部分)reader.cE:\C++程序\资料室管理系统\reader.c(2) : error C2143: syntax error : missing ')' before '&'E:\C++程序\资料室管理系统\reader.c(2) : error C2143: syntax error : missing '{' before '&'E:\C++程序\资料室管理系统\reader.c(2) : error C2059: syntax error : '&'E:\C++程序\资料室管理系统\reader.c(2) : error C2059: syntax error : ')'readfile.cE:\C++程序\资料室管理系统\readfile.c(2) : error C2143: syntax error : missing ')' before '&'E:\C++程序\资料室管理系统\readfile.c(2) : error C2143: syntax error : missing '{' before '&'E:\C++程序\资料室管理系统\readfile.c(2) : error C2059: syntax error : '&'E:\C++程序\资料室管理系统\readfile.c(2) : error C2059: syntax error : ')'search.cE:\C++程序\资料室管理系统\search.c(2) : error C2146: syntax error : missing ')' before identifier 'bif'E:\C++程序\资料室管理系统\search.c(2) : error C2061: syntax error : identifier 'bif'E:\C++程序\资料室管理系统\search.c(2) : error C2059: syntax error : ';'E:\C++程序\资料室管理系统\search.c(2) : error C2059: syntax error : ','E:\C++程序\资料室管理系统\search.c(2) : error C2059: syntax error : ')'
展开
3个回答
展开全部
#include "stdio.h"
#include "stdlib.h"
#define OK 1
#define ERROR 0
#define OVERFLOW -1
//#define EOF -1
#define STACK_INIT_SIZE 10
#define STACKINCREMENT 1000
#define MAXQSIZE 10
static int i=0;
typedef char ElemType;
typedef struct StackNode//构造栈
{
ElemType *base;
ElemType *top;
int stacksize;
}SqStack;
ElemType InitStack(SqStack *S)//初始化栈
{
S->base=(ElemType *)malloc(STACK_INIT_SIZE*sizeof(ElemType));
if(!S->base)
{
exit(OVERFLOW);
}
S->top=S->base;
S->stacksize=STACK_INIT_SIZE;
return OK;
}
ElemType StackEmpty(SqStack *S)//判断栈是否为空
{
if(S->top==S->base)
return OK;
else
return ERROR;
}
ElemType Push(SqStack *S,ElemType e)//进栈操作
{
if(S->top-S->base>=S->stacksize)
{
S->base = (ElemType *)realloc(S->base,(S->stacksize+STACKINCREMENT)*sizeof(ElemType));
if(!S->base)
{
exit(OVERFLOW);
}
S->top = S->base+S->stacksize;
S->stacksize+=STACKINCREMENT;
}
*S->top++=e;
return OK;
}
ElemType Pop(SqStack *S,ElemType *e)//出栈操作
{
if(S->top==S->base)
{
return ERROR;
}
*e=*--S->top;
//printf("%d\n",e);
// return e;
return 0;
}
void ClearStack(SqStack *S)//清空栈
{
S->top=S->base;
}
ElemType LineEdit(SqStack *S )//文本编译
{
char ch, e, a[30];
int i ;
ch = getchar();
while(1)
{
while (ch!='\n')
{
switch(ch)
{
case '#': Pop(S,&e); break; //遇到'#',前面个字符出栈
case '@': ClearStack(S); break; //遇到'@',前面的所以字符出栈
default: Push(S,ch); break; //其他字符进栈
}
ch = getchar();
}
i = 0;
while (!StackEmpty(S))
{
Pop(S,&e);
a[i++]=e;
}
printf("循环输出结果为:");
for(--i; i>= 0; i--)
{
printf("%c",a[i]);
}
printf("\n请再输入几个字符吧:");
ClearStack(S);
ch = getchar();
}
return 0;
}
int main(void)
{
SqStack S;
printf("\n\t\t\t本程序是用C语言演示数据结构中的栈\n\n");
printf("\t说明:首先连续输入几个字符初始化栈,以换行结束.\n");
printf("\t如果输入字符中包含'#',那么它前面的一个字符就会出栈,\n");
printf("\t如果输入的字符中包括'@',那么它前面的所有字符全部出栈(清空)!\n");
printf("\t程序本身就这么简单,唯一不足的一点就是无限循环输入,没有结束语句!\n");
printf("\t程序重要其价值,这一点可以说是程序不足的不足吧!\n");
printf("\t祝你早日成功哈!\n\n");
printf("请连续输入几个字符初始化栈(eg:abc):");
InitStack(&S);
LineEdit(&S);
system("pause");
return 0;
}
这一下差不多行了。。
所谓的界面友好就是要提示用户输入什么。。。
要不然的话用户都不知道怎么输入那怎么能行呢。。
关键还是提示语句。。。
都说我暂时退出江湖了。。
最近一段时间忙着找工作呢。。
可是友人找到我了。。
即使是搞JAVA了也得帮友人一把。。。
数据结构虽说学得不怎么好。。。
但还没全忘。。嘿嘿。。。
祝朋友早日成功啦!!!
bye-bye!
对了,还有件事忘了讲了。。。
就是分嘛。。。千万别动不动全部都给别人。。
你又不是问了这次就不问下次了。。
留着以后还用的着呢。。
随便一点意思意思就很OK了。。。
兄弟还在乎那几个分。。
嘿嘿。。。。
#include "stdlib.h"
#define OK 1
#define ERROR 0
#define OVERFLOW -1
//#define EOF -1
#define STACK_INIT_SIZE 10
#define STACKINCREMENT 1000
#define MAXQSIZE 10
static int i=0;
typedef char ElemType;
typedef struct StackNode//构造栈
{
ElemType *base;
ElemType *top;
int stacksize;
}SqStack;
ElemType InitStack(SqStack *S)//初始化栈
{
S->base=(ElemType *)malloc(STACK_INIT_SIZE*sizeof(ElemType));
if(!S->base)
{
exit(OVERFLOW);
}
S->top=S->base;
S->stacksize=STACK_INIT_SIZE;
return OK;
}
ElemType StackEmpty(SqStack *S)//判断栈是否为空
{
if(S->top==S->base)
return OK;
else
return ERROR;
}
ElemType Push(SqStack *S,ElemType e)//进栈操作
{
if(S->top-S->base>=S->stacksize)
{
S->base = (ElemType *)realloc(S->base,(S->stacksize+STACKINCREMENT)*sizeof(ElemType));
if(!S->base)
{
exit(OVERFLOW);
}
S->top = S->base+S->stacksize;
S->stacksize+=STACKINCREMENT;
}
*S->top++=e;
return OK;
}
ElemType Pop(SqStack *S,ElemType *e)//出栈操作
{
if(S->top==S->base)
{
return ERROR;
}
*e=*--S->top;
//printf("%d\n",e);
// return e;
return 0;
}
void ClearStack(SqStack *S)//清空栈
{
S->top=S->base;
}
ElemType LineEdit(SqStack *S )//文本编译
{
char ch, e, a[30];
int i ;
ch = getchar();
while(1)
{
while (ch!='\n')
{
switch(ch)
{
case '#': Pop(S,&e); break; //遇到'#',前面个字符出栈
case '@': ClearStack(S); break; //遇到'@',前面的所以字符出栈
default: Push(S,ch); break; //其他字符进栈
}
ch = getchar();
}
i = 0;
while (!StackEmpty(S))
{
Pop(S,&e);
a[i++]=e;
}
printf("循环输出结果为:");
for(--i; i>= 0; i--)
{
printf("%c",a[i]);
}
printf("\n请再输入几个字符吧:");
ClearStack(S);
ch = getchar();
}
return 0;
}
int main(void)
{
SqStack S;
printf("\n\t\t\t本程序是用C语言演示数据结构中的栈\n\n");
printf("\t说明:首先连续输入几个字符初始化栈,以换行结束.\n");
printf("\t如果输入字符中包含'#',那么它前面的一个字符就会出栈,\n");
printf("\t如果输入的字符中包括'@',那么它前面的所有字符全部出栈(清空)!\n");
printf("\t程序本身就这么简单,唯一不足的一点就是无限循环输入,没有结束语句!\n");
printf("\t程序重要其价值,这一点可以说是程序不足的不足吧!\n");
printf("\t祝你早日成功哈!\n\n");
printf("请连续输入几个字符初始化栈(eg:abc):");
InitStack(&S);
LineEdit(&S);
system("pause");
return 0;
}
这一下差不多行了。。
所谓的界面友好就是要提示用户输入什么。。。
要不然的话用户都不知道怎么输入那怎么能行呢。。
关键还是提示语句。。。
都说我暂时退出江湖了。。
最近一段时间忙着找工作呢。。
可是友人找到我了。。
即使是搞JAVA了也得帮友人一把。。。
数据结构虽说学得不怎么好。。。
但还没全忘。。嘿嘿。。。
祝朋友早日成功啦!!!
bye-bye!
对了,还有件事忘了讲了。。。
就是分嘛。。。千万别动不动全部都给别人。。
你又不是问了这次就不问下次了。。
留着以后还用的着呢。。
随便一点意思意思就很OK了。。。
兄弟还在乎那几个分。。
嘿嘿。。。。
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询