一直提示 error C2146: syntax error : missing ';' before identifier 'i'
fatal error C1004: unexpected end of file found
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define NULL 0
#define OK 1
#define ERROR -1
#define STACK_INIT_SIZE 100
#define STACKINCREMENT 20
#pragma warning(disable:4518)
/* 定義字符型別堆疊*/
typedef struct{
int stacksize;
char *base;
char *top;
} Stack;
/* 定義整型堆疊*/
typedef struct{
int stacksize;
int *base;
int *top;
} Stack2;
/* ----------------- 全域變數--------------- */
Stack OPTR;/* 定義運算子堆疊*/
Stack2 OPND; /* 定義運算元堆疊 */
char expr[255] = ""; /* 存放運算式串 */
char *ptr = expr;
int InitStack(Stack *s) //構造運算子堆疊
{
s->base=(char *)malloc(STACK_INIT_SIZE*sizeof(char));
if(!s->base) return ERROR;
s->top=s->base;
s->stacksize=STACK_INIT_SIZE;
return OK;
}
int InitStack2(Stack2 *s) //構造運算元堆疊
{
s->base=(int *)malloc(STACK_INIT_SIZE*sizeof(int));
if(!s->base) return ERROR;
s->stacksize=STACK_INIT_SIZE;
s->top=s->base;
return OK;
}
int In(char ch) //判斷字符是否是運算子,運算子即回傳1
{
return(ch=='+'||ch=='-'||ch=='*'||ch=='/'||ch=='('||ch==')'||ch=='#');
}
int Push(Stack *s,char ch) //運算子堆疊插入ch為新的堆疊頂元素
{
*s->top=ch;
s->top++;
return 0;
}
int Push2(Stack2 *s,int ch)//運算元堆疊插入ch為新的堆疊頂元素
{
*s->top=ch;
s->top++;
return 0;
}
char Pop(Stack *s) //洗掉運算子堆疊s的堆疊頂元素,用p回傳其值
{
char p;
s->top--;
p=*s->top;
return p;
}
int Pop2(Stack2 *s)//洗掉運算元堆疊s的堆疊頂元素,用p回傳其值
{
int p;
s->top--;
p=*s->top;
return p;
}
char GetTop(Stack s)//用p回傳運算子堆疊s的堆疊頂元素
{
char p=*(s.top-1);
return p;
}
int GetTop2(Stack2 s) //用p回傳運算元堆疊s的堆疊頂元素
{
int p=*(s.top-1);
return p;
}
/* 判斷運算子優先權,回傳優先權高的 */
char Precede(char c1,char c2)
int i=0,j=0;
static char array[49]={
'>', '>', '<', '<', '<', '>', '>',
'>', '>', '<', '<', '<', '>', '>',
'>', '>', '>', '>', '<', '>', '>',
'>', '>', '>', '>', '<', '>', '>',
'<', '<', '<', '<', '<', '=', '!',
'>', '>', '>', '>', '!', '>', '>',
'<', '<', '<', '<', '<', '!', '='};
switch(c1)
{
/* i為下面array的橫標*/
case '+' : i=0;break;
case '-' : i=1;break;
case '*' : i=2;break;
case '/' : i=3;break;
case '(' : i=4;break;
case ')' : i=5;break;
case '#' : i=6;break;
}
switch(c2)
{
/* j為下面array的縱標 */
case '+' : j=0;break;
case '-' : j=1;break;
case '*' : j=2;break;
case '/' : j=3;break;
case '(' : j=4;break;
case ')' : j=5;break;
case '#' : j=6;break;
}
return (array[7*i+j]); /* 回傳運算子 */
}
/*操作函式 */
int Operate(int a,char op,int b)
{
switch(op)
{
case '+' : return (a+b);
case '-' : return (a-b);
case '*' : return (a*b);
case '/' : return (a/b);
}
return 0;
}
int num(int n)//回傳運算元的長度
{
char p[10];
itoa(n,p,10);//把整型轉換成字串型
n=strlen(p);
return n;
}
int EvalExpr()//主要操作函式
{
char c,theta,x; int n,m;
int a,b;
c = *ptr++;
while(c!='#'||GetTop(OPTR)!='#')
{
if(!In(c))
{ if(!In(*(ptr-1))) ptr=ptr-1;
m=atoi(ptr);//取字串前面的數欄位
n=num(m);
Push2(&OPND,m);
ptr=ptr+n;
c=*ptr++;
}
else
switch(Precede(GetTop(OPTR),c))
{
case '<':
Push(&OPTR,c);
c = *ptr++;
break;
case '=':
x=Pop(&OPTR);
c = *ptr++;
break;
case '>':
theta=Pop(&OPTR);
b=Pop2(&OPND); a=Pop2(&OPND);
Push2(&OPND,Operate(a,theta,b));
break;
}
}
return GetTop2(OPND);
}
int main( )
{
printf("請輸入正確的運算式以'#'結尾:");
do{
gets(expr);
}while(!*expr);
InitStack(&OPTR); /* 初始化運算子堆疊 */
Push(&OPTR,'#'); /* 將#壓入運算子堆疊 */
InitStack2(&OPND); /* 初始化運算元堆疊 */
printf("運算式結果為:%d\n", EvalExpr());
return 0;
}
uj5u.com熱心網友回復:
char Precede(char c1,char c2) 這個后面少個 分號 ;uj5u.com熱心網友回復:
還有,貼代碼可以使用 代碼格式, 就在笑臉圖示的左邊那個帶下拉選單有尖括號的圖示。轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/85971.html
標籤:VCL組件使用和開發
