习题3.11 表达式转换 (25分)
算术表达式有前缀表示法、中缀表示法和后缀表示法等形式。日常使用的算术表达式是采用中缀表示法,即二元运算符位于两个运算数中间。请设计程序将中缀表达式转换为后缀表达式。
输入格式:
输入在一行中给出不含空格的中缀表达式,可包含+、-、*、/以及左右括号(),表达式不超过20个字符。
输出格式:
在一行中输出转换后的后缀表达式,要求不同对象(运算数、运算符号)之间以空格分隔,但结尾不得有多余空格。
输入样例:
2+3*(7-4)+8/4
输出样例:
2 3 7 4 - * + 8 4 / +
刚开始尝试的时候一直显示“格式错误”,网上检索阅读了蒋赟jiangyun的一篇博客后才知道自己的问题在哪里:没有考虑连续输入数字的情况,例如123,仅考虑了单个数字的输入。。。
原文链接:https://blog.csdn.net/weixin_42240329/article/details/84192447
C语言代码如下:
#include <stdio.h>
#include<stdlib.h>
struct S
{
char *data;
int top;
int maxsize;
};
typedef struct S * Stack;
void push(Stack S, char c);
char pop(Stack S);
int main()
{
Stack St;
St = (Stack)malloc(sizeof(struct S));
St->data = (char *)malloc(21 * sizeof(char));
St->top = -1;
St->maxsize = 21;
char a[40];
char c;
int i = 0;
while ((a[i++] = getchar()) != '\n'); //读入数据
a[i] = '\0';
i = 0;
int flag = 1; //为了保证数字连续输入时,可以连续输出,例如输入123,输出123,而不是1 2 3
while (a[i] != '\0')
{
if (a[i]

本文介绍了一种使用C语言实现的算法,用于将中缀表达式转换为后缀表达式,详细解释了处理连续数字输入的问题,并提供了完整的代码示例。

2295

被折叠的 条评论
为什么被折叠?



