后缀表达式求值c语言
时间: 2023-12-02 13:38:14 浏览: 51
后缀表达式求值可以使用栈来实现。具体步骤如下:
1. 创建一个空栈,用于存储操作数。
2. 从左到右遍历后缀表达式中的每个元素。
3. 如果当前元素是操作数,则将其压入栈中。
4. 如果当前元素是操作符,则从栈中弹出两个操作数,进行相应的运算,并将结果压入栈中。
5. 遍历完后缀表达式后,栈中只剩下一个元素,即为表达式的值。
下面是一个示例代码:
```c
#include <stdio.h>
#include <stdlib.h>
#include <ctype.h>
#define MAX_SIZE 100
typedef struct {
int top;
int data[MAX_SIZE];
} Stack;
void init(Stack *s) {
s->top = -1;
}
void push(Stack *s, int x) {
if (s->top == MAX_SIZE - 1) {
printf("Stack overflow\n"); exit(1);
}
s->data[++s->top] = x;
}
int pop(Stack *s) {
if (s->top == -1) {
printf("Stack underflow\n");
exit(1);
}
return s->data[s->top--];
}
int evaluate(char *expr) {
Stack s;
init(&s);
for (int i = 0; expr[i] != '\0'; i++) {
if (isdigit(expr[i])) {
push(&s, expr[i] - '0');
} else if (expr[i] == '+' || expr[i] == '-' || expr[i] == '*' || expr[i] == '/') {
int op2 = pop(&s);
int op1 = pop(&s);
switch (expr[i]) {
case '+':
push(&s, op1 + op2);
break;
case '-':
push(&s, op1 - op2);
break;
case '*':
push(&s, op1 * op2);
break;
case '/':
push(&s, op1 / op2);
break;
}
}
}
return pop(&s);
}
int main() {
char expr[] = "23+4*";
int result = evaluate(expr);
printf("%d\n", result);
return 0;
}
```