C语言:中缀表达式求值,输入9+3*6,输出27
时间: 2024-02-28 11:56:27 浏览: 22
以下是C语言代码实现:
```c
#include <stdio.h>
int main() {
char op; // 存储运算符
int num, result;
scanf("%d", &result);
while (scanf("%c%d", &op, &num) != EOF) {
if (op == '+') {
result += num;
} else if (op == '-') {
result -= num;
} else if (op == '*') {
result *= num;
} else if (op == '/') {
result /= num;
}
}
printf("%d\n", result);
return 0;
}
```
这段代码中,我们首先读入一个数字作为结果。然后使用一个循环,每次读入一个运算符和一个数字,根据运算符更新结果。最终输出结果即可。
相关问题
C语言:中缀表达式计算结果,只包含加法和乘法,例如输入9+3*6,输出27
可以通过栈来实现中缀表达式的计算。具体步骤如下:
1. 定义一个栈,用于存储数字和运算符。
2. 从左到右遍历中缀表达式中的每一个字符。
3. 如果当前字符是数字,则将其入栈。
4. 如果当前字符是运算符,则取出栈顶的两个数字进行运算,并将结果入栈。
5. 遍历完整个中缀表达式后,栈内只剩下一个元素,即为表达式的计算结果。
以下是一个示例代码:
```c
#include <stdio.h>
#include <stdlib.h>
#include <ctype.h>
#define STACK_SIZE 100
typedef struct {
int data[STACK_SIZE];
int top;
} Stack;
void init(Stack *s) {
s->top = -1;
}
void push(Stack *s, int value) {
if (s->top >= STACK_SIZE - 1) {
printf("Stack overflow");
exit(1);
}
s->data[++s->top] = value;
}
int pop(Stack *s) {
if (s->top < 0) {
printf("Stack underflow");
exit(1);
}
return s->data[s->top--];
}
int main() {
Stack s;
char c;
int num1, num2;
init(&s);
while ((c = getchar()) != '\n') {
if (isdigit(c)) {
push(&s, c - '0');
} else if (c == '+') {
num2 = pop(&s);
num1 = pop(&s);
push(&s, num1 + num2);
} else if (c == '*') {
num2 = pop(&s);
num1 = pop(&s);
push(&s, num1 * num2);
}
}
printf("Result: %d", pop(&s));
return 0;
}
```
如果输入9+3*6,输出结果为27。
C语言:中缀表达式求值
C语言中缀表达式求值一般采用栈来实现,具体步骤如下:
1. 定义一个操作数栈和一个操作符栈。
2. 从左到右依次扫描表达式的每个元素,如果是数字则将其压入操作数栈中,如果是操作符则比较其与操作符栈栈顶元素的优先级。
3. 如果该操作符优先级高于栈顶操作符,则将该操作符压入操作符栈中。
4. 否则,将操作符栈栈顶元素弹出,从操作数栈中弹出两个数字,进行计算并将结果压入操作数栈中,直到该操作符可以入栈。
5. 如果扫描完整个表达式后,操作符栈不为空,则将操作符栈中的操作符依次弹出,从操作数栈中弹出两个数字进行计算并将结果压入操作数栈中。
6. 最终操作数栈中剩下的数字即为表达式的值。
例如,对于中缀表达式 "2 + 3 * 4 - 5",按照上述步骤可以得到如下计算过程:
1. 将2压入操作数栈中。
2. 将"+"压入操作符栈中。
3. 将3压入操作数栈中。
4. 将"*"与操作符栈栈顶元素"+"比较,"*"的优先级高,将"*"压入操作符栈中。
5. 将4压入操作数栈中。
6. 将"-"与操作符栈栈顶元素"*"比较,"-"的优先级低,将"*"弹出,从操作数栈中弹出4和3进行计算得到12,将12压入操作数栈中。
7. 将"-"压入操作符栈中。
8. 将5压入操作数栈中。
9. 扫描完整个表达式后,操作符栈中剩余"-",将"*"弹出,从操作数栈中弹出12和2进行计算得到24,将24压入操作数栈中,将"-"弹出,从操作数栈中弹出24和5进行计算得到19,最终操作数栈中剩下的数字19即为表达式的值。