zoukankan      html  css  js  c++  java
  • 7-20 表达式转换 (25分)

    算术表达式有前缀表示法、中缀表示法和后缀表示法等形式。日常使用的算术表达式是采用中缀表示法,即二元运算符位于两个运算数中间。请设计程序将中缀表达式转换为后缀表达式。

    输入格式:

    输入在一行中给出不含空格的中缀表达式,可包含+-*以及左右括号(),表达式不超过20个字符。

    输出格式:

    在一行中输出转换后的后缀表达式,要求不同对象(运算数、运算符号)之间以空格分隔,但结尾不得有多余空格。

    输入样例:

    2+3*(7-4)+8/4
    
     

    输出样例:

    2 3 7 4 - * + 8 4 / +
    当初写的时候死活没考虑到会有小数的情况和运算数前有正负号的情况都快自闭了
    看来被人的blog才知道,怪自己脑子惯性思维,做一个合格的程序猿还是要善于找各种bug啊
    写的时候左改右改导致代码很难看,,见谅
    /*
        Name:
        Copyright:
        Author:  流照君
        Date: 2019/8/13 10:14:26
        Description:
    */
    #include <iostream>
    #include<string>
    #include <algorithm>
    #include <vector>
    #include<stack>
    #define inf 0x3f3f3f3f
    using namespace std;
    typedef long long ll;
    stack<char> st;
    bool check(char c)
    {
        char s=st.top();
        if((c=='-'||c=='+')&&(s=='('))
        return true;
        else if((c=='*'||c=='/')&&(s=='-'||s=='+'||s=='('))
        return true;
        else if(c=='(')
        return true;
        else
        return false;
    }
    bool check1(char c)
    {
        char s=st.top();
        if (s=='*'||s=='/')
        return true;
        else if ((c=='-'||c=='+')&&(s=='-'||s=='+'))
        return true;
        else 
        return false;
    }
    int main(int argc, char** argv)
    {
        //freopen("in.txt", "r", stdin);
        //freopen("out.txt", "w", stdout);
        int tag=1,flag=1;
        string s;
        cin>>s;
        int n=s.size();
        for(int i=0;i<n;i++)
        {
            if(!isdigit(s[i]))
             flag=0;
        }
        if(flag==1)
        {
            cout<<s;
            return 0;
        }
        for(int i=0;i<n;i++)
        {
            if(isdigit(s[i])||s[i]=='.')
            {
                while(isdigit(s[i+1])||s[i+1]=='.')
                {
                cout<<s[i];
                i=i+1;
                }
                cout<<s[i]<<" "; 
                tag=0;
            }
            else if((s[i]=='+'||s[i]=='-')&&tag==1&&isdigit(s[i+1])&&i<n-1)
                {
                    if(s[i]=='-')
                    cout<<s[i];
                }
            else if(st.empty()||check(s[i]))
            {
                st.push(s[i]);
                tag=1; 
            }
            else if(s[i]==')')
            {
                while(st.top()!='(')
                {
                    cout<<st.top()<<" ";
                    st.pop();
                }
                st.pop();
                //cout<<"eefeff"<<endl;
            }
            else if(check1(s[i]))
            {
                while(check1(s[i]))
                {
                    cout<<st.top()<<" ";
                    st.pop();
                    if(st.empty())
                    break;
                }
                st.push(s[i]);
                tag=1;
                //cout<<s[i]<<"www"<<endl;
            }
        }
        if(st.size()==1)
        {
            cout<<st.top();
        }
        else 
        {
            while(!st.empty())
            {
                if(st.size()==1)
                {
                cout<<st.top();
                break;
                }
                else
                {
                    cout<<st.top()<<" ";
                    st.pop();
                }
            }
        }     
        return 0;
  • 相关阅读:
    Map与对象关系的思考之P1563玩具谜题
    vector性能调优之resize与reserve
    模拟--P1328 生活大爆炸版石头剪刀布 题解
    模拟--P1540 机器翻译
    get、post、put、delete
    Java POI 导出EXCEL经典实现 Java导出Excel弹出下载框(转载)
    Docker(4) 制作镜像
    Git(1) 常用命令
    Linux(1) 常用命令
    Docker(3) 基础知识
  • 原文地址:https://www.cnblogs.com/liuzhaojun/p/12346907.html
Copyright © 2011-2022 走看看