SDUTOJ-1646-Complicated Expressions-二叉树的建立

本文介绍了一种使用二叉树来解析数学表达式的算法。通过递归地将输入字符串转换为二叉树结构,该算法能正确处理运算符优先级和括号,并通过中序遍历生成最终表达式。文章详细解释了构建和遍历二叉树的过程。

由题意,我们可以建立一个二叉树。

然后中序遍历二叉树,得到最终的结果。

在中序遍历二叉树的时候,我们判断当前子树的根节点与其子节点的符号之间的关系。

#include<stdio.h>
#include<string.h>
#include<iostream>
#include<algorithm>
#include<vector>
#include<stack>
#define LL long long
#define INF 1000000000
using namespace std;
struct list
{
    char x;
    int l;
    int r;
    int leap;
} node[5001];
char str[10001];
int vnum;
int dos(int x,int y)//把str字符串从x到y这一段转化成
{                  //一颗二叉树,并且返回这颗二叉树的根节点
    int i,j;
    if(x==y)
    {
        node[vnum].l=-1;
        node[vnum].r=-1;
        node[vnum].x=str[x];
        node[vnum].leap=0;
        vnum++;
        return vnum-1;
    }
    int vis[1001];
    stack<int>st;
    while(!st.empty())st.pop();
    vector<int>vec;
    vec.clear();
    int ns,ss;
    for(i=x; i<=y; i++)
    {
        if(str[i]=='(')
        {
            int sts=1;
            for(j=i+1; j<=y; j++)
            {
                if(str[j]=='(')sts++;
                if(str[j]==')')sts--;
                if(sts==0)break;
            }
            int pp=dos(i+1,j-1);
            vec.push_back(pp);
            node[pp].leap=0;
            i=j;
        }
        else
        {
            vec.push_back(vnum);
            node[vnum].l=-1;
            node[vnum].r=-1;
            node[vnum].leap=1;
            node[vnum].x=str[i];
            vnum++;

        }
    }
    int len=vec.size();
    int ks[1001];
    int knum;
    knum=0;
    for(i=0; i<len; i++)
    {
        int pp=vec[i];
        if((node[pp].leap==1)&&(node[pp].x=='*'||node[pp].x=='/'))
        {
            int xx=ks[knum-1];
            knum--;
            node[pp].l=xx;
            node[pp].r=vec[i+1];
            i++;
        }
        ks[knum++]=pp;
    }
    int pa;
    pa=ks[0];
    for(i=1; i<knum; i++)
    {
        int pp=ks[i];
        node[pp].l=pa;
        node[pp].r=ks[i+1];
        pa=pp;
        i++;
    }
    return pa;
}
int need(int x,int y,int leap)//判断以x为根,以y为子节点,在中序遍历的时候是否需要加()
{
    if(node[x].x=='/'&&leap==1)
    {
        if(node[y].x=='+'||node[y].x=='-'||node[y].x=='*'||node[y].x=='/')return 1;
    }
    if(node[x].x=='*'||node[x].x=='/')
    {
        if(node[y].x=='+'||node[y].x=='-')return 1;
    }
    if(node[x].x=='-'&&leap==1)
    {
        if(node[y].x=='+'||node[y].x=='-')return 1;
    }
    return 0;
}
void print(int x)//输出以x为根节点的中序遍历结果
{
    if(node[x].l!=-1)
    {
        int ll=node[x].l;
        if(need(x,ll,0))
        {
            putchar('(');
            print(ll);
            putchar(')');
        }
        else
        {
            print(ll);
        }
    }
    putchar(node[x].x);
    if(node[x].r!=-1)
    {
        int ll=node[x].r;
        if(need(x,ll,1))
        {
            putchar('(');
            print(ll);
            putchar(')');
        }
        else
        {
            print(ll);
        }
    }

}
int main()
{
    int _,i,j;
    scanf("%d",&_);
    for(j=1; j<=_; j++)
    {
        vnum=0;
        scanf("%s",str);
        int len=strlen(str);
        int st=dos(0,len-1);
        print(st);
        cout<<endl;
    }
    return 0;
}



内容概要:本文档详细介绍了基于直驱永磁同步发电机(PMSG)的1.5MW风力发电系统在Simulink环境下的建模与仿真全过程,涵盖了风力机空气动力学模型、PMSG电磁特性建模、不可控整流与逆变电路、直流环节、空间矢量脉宽调制(SVPWM)技术以及核心控制策略的设计。重点实现了最大功率点跟踪(MPPT)控制以提升风能捕获效率,并构建了电压外环与电流内环协同工作的双闭环控制系统,通过仿真验证了系统在不同风速条件下稳定运行的能力及动态响应性能。; 适合人群:适用于具备电力系统、电机控制理论基础及Simulink仿真操作经验的研究生、科研人员和从事新能源发电系统开发的工程技术人员;特别适合正在进行风电系统建模、控制算法研究或完成相关毕业设计的专业人士。; 使用场景及目标:①深入理解直驱式PMSG风力发电系统的整体架构与工作机理;②掌握从物理部件建模到控制策略实现的完整Simulink仿真流程;③学习并复现MPPT控制、双闭环控制等关键技术方案;④为后续开展低电压穿越、并网稳定性分析、故障诊断等高级课题提供可靠的仿真平台支撑。; 阅读建议:建议结合Matlab/Simulink软件动手实践,逐模块搭建模型,重点关注各控制环节的参数设计与调试方法,同时可参照文中提供的其他风电相关资源进行拓展学习与对比分析。
已经博主授权,源码转载自 https://pan.quark.cn/s/868afdd63918 在信息技术领域中,前端开发构成了Web应用程序构建的关键环节,而登录注册页面则是用户与网站进行互动的起始界面。"150款web登录注册页面模板(附带效果图+源码)"这一资源为前端工程师们提供了一系列预先设计的界面组件,支持他们迅速构建既美观又实用的登录及注册界面,从而有效缩减开发周期并增强工作效率。 这些模板囊括了多样化的风格和设计潮流,涵盖了扁平化设计、Material Design、渐变色彩、暗黑模式等,能够适应不同项目的特定要求。在设计中强调用户体验,通过科学的布局安排,提升了表单的便捷操作性和可辨识度,并且不忽视视觉层面的吸引力。设计师通常会关注自适应设计,保证页面在多种设备(涵盖手机、平板及桌面电脑)上均能呈现良好的视觉效果。 这些模板均配备了源代码,使得开发者得以深入探究并个性化定制每个构成部分,涉及HTML的页面构造、CSS的样式修饰以及JavaScript的交互逻辑。HTML主要承担着页面基础结构的搭建,CSS用于实现页面美化与布局控制,JavaScript则常用于处理表单验证和交互效果。对于那些精通这三种技术的开发者而言,他们可以根据个人需求对模板进行功能扩展和样式调整。 在实际部署时,登录注册页面通常需要集成基础的输入项,例如用户名、密码、电子邮箱等,并且必须重视安全性考量,诸如密码强度指引、验证码系统等。除此之外,为了优化用户体验,还可能集成记住密码、自动填充、社交平台登录(例如微信、QQ、微博)等功能。 在开发阶段,前端工程师还需关注Web标准和无障碍访问(WCAG)规范,确保页面的通用友好性,这包括视障、听障或其他有特殊需求的用户群体。具体措施涉及标...
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值