weixin_58448813 2021-10-04 22:04 采纳率: 100%
浏览 95
已结题

Matlab将中缀表达式变为后缀表达式(急!!)

求完整能运行程序!
考虑 + - * /四个运算符和()各类情况。
只要matlab的!

  • 写回答

2条回答 默认 最新

  • slandarer MATLAB领域优质创作者 2021-10-04 23:55
    关注

    写了个函数:

    function strStack=in2postFix(strFunc)
    symStack='';
    strStack='';
    
    strLast='';
    for i=1:length(strFunc)
        strTemp=strFunc(1);
        strFunc(1)=[];    
        if isstrprop(strTemp,'digit')   
            if ~isempty(strStack)&&~isstrprop(strStack(end),'digit')
                strStack=[strStack,strTemp];
            elseif isstrprop(strLast,'digit')
                strStack=[strStack,strTemp];
            else
                if ~isempty(strStack)
                    strStack=[strStack,' ',strTemp];
                else
                    strStack=[strStack,strTemp];
                end
            end
        else
            tPos=find(symStack=='(',1,'last');
            switch strTemp
                case '+'
                    symStack=[symStack,'+'];
                    if isempty(tPos)
                        strStack=[strStack,symStack(end-1:-1:1)];
                        symStack(end-1:-1:1)=[];
                    else
                        strStack=[strStack,symStack(end-1:-1:tPos+1)];
                        symStack(end-1:-1:tPos+1)=[];
                    end
                case '-'
                    symStack=[symStack,'-'];
                    if isempty(tPos)
                        strStack=[strStack,symStack(end-1:-1:1)];
                        symStack(end-1:-1:1)=[];
                    else
                        strStack=[strStack,symStack(end-1:-1:tPos+1)];
                        symStack(end-1:-1:tPos+1)=[];
                    end
                case '*'
                    symStack=[symStack,'*'];
                case '/'
                    symStack=[symStack,'/'];
                    if length(symStack)>1&&symStack(end-1)=='*'
                        strStack=[strStack,'*'];
                        symStack(end-1)=[];
                    end
                case '('
                    symStack=[symStack,'('];
                case ')'
                    strStack=[strStack,symStack(end:-1:tPos+1)];
                    symStack(end:-1:tPos)=[];
            end
        end
        strLast=strTemp;
    end
    strStack=[strStack,symStack(end:-1:1)];
    end
    

    使用实例:

    strFunc='24*(3+4/5-5)/5+26';
    in2postFix(strFunc)
    

    运行结果:
    24 3 4 5/+5-*5/26+

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 10月13日
  • 已采纳回答 10月5日
  • 创建了问题 10月4日

悬赏问题

  • ¥15 宇视监控服务器无法登录
  • ¥15 PADS Logic 原理图
  • ¥15 PADS Logic 图标
  • ¥15 电脑和power bi环境都是英文如何将日期层次结构转换成英文
  • ¥20 气象站点数据求取中~
  • ¥15 如何获取APP内弹出的网址链接
  • ¥15 wifi 图标不见了 不知道怎么办 上不了网 变成小地球了
  • ¥50 STM32单片机传感器读取错误
  • ¥50 power BI 从Mysql服务器导入数据,但连接进去后显示表无数据
  • ¥15 (关键词-阻抗匹配,HFSS,RFID标签天线)