首页 > 其他分享 >SDUT DAG优化

SDUT DAG优化

时间:2023-01-16 21:25:22浏览次数:38  
标签:DAG int tr dfs char SDUT ans 优化

SDUT DAG优化

题目描述

大家都学过了代码优化,其中有一个DAG优化,这次我们就练习这个操作。

输入

输入第一行为一个整数n(n < 100),表示该组输入的表达式的个数
之后n行为表达式,每个变量为一个字母,表达式仅包括二元运算 + - * /
保证AB的值不同,例如:A=B+C。

输出

通过构造DAG图,进行代码优化,只需要保留AB,删除无用变量,删除变量时,尽量保留最早出现的变量。

Input

3
A=B+C
B=B+B
A=C+C

Output

B=B+B
A=C+C

代码

#include <bits/stdc++.h>
using namespace std;
int falg[11111], n;
char ans[11111][11111];
struct node
{
    int l, r;
    char op;
    vector<char> fu;
} tr[1000];
int cnt = 0;
void dfs(int x)
{
    if (tr[x].l && tr[x].r)
    {
        falg[x] = 1;
        dfs(tr[x].l);
        dfs(tr[x].r);
    }
}

int make(char x)
{
    for (int i = 1; i <= cnt; i++)
        if (find(tr[i].fu.begin(), tr[i].fu.end(), x) != tr[i].fu.end() || tr[i].op == x)
            return i;
    tr[++cnt].op = x;
    return cnt;
}

void add(char root, int l, int r, char op)
{
    for (int i = 1; i <= cnt; i++)
        if (tr[i].l == l && tr[i].r == r && tr[i].op == op)
        {
            tr[i].fu.push_back(root);
            return;
        }
    tr[++cnt] = {l, r, op};
    tr[cnt].fu.push_back(root);
}

void solve(int id, int pos, int ci)
{
    if (tr[id].fu.size() == 0)
    {
        ans[pos][ci] = tr[id].op;
        return;
    }
    for (int i = 0; i < tr[id].fu.size(); i++)
        if (tr[id].fu[i] == 'A' || tr[id].fu[i] == 'B')
        {
            ans[pos][ci] = tr[id].fu[i];
            return;
        }
    ans[pos][ci] = tr[id].fu[0];
}

signed main()
{
    cin >> n;
    for (int i = 0; i < n; i++)
    {
        string s;
        cin >> s;
        int l = make(s[2]), r = make(s[4]);
        char root = s[0], op = s[3];
        add(root, l, r, op);
    }
    for (int i = 1; i <= cnt; i++)
        if (tr[i].l && tr[i].r)
        {
            ans[i][1] = '=', ans[i][3] = tr[i].op, ans[i][5] = '\0';
            solve(i, i, 0);
            solve(tr[i].l, i, 2);
            solve(tr[i].r, i, 4);
        }

    for (int i = cnt; i >= 1; i--)
        if (ans[i][0] == 'A')
        {
            dfs(i);
            break;
        }
    for (int i = cnt; i >= 1; i--)
        if (ans[i][0] == 'B')
        {
            dfs(i);
            break;
        }

    for (int i = 1; i <= cnt; i++)
        if (falg[i])
            cout << ans[i] << endl;
}

标签:DAG,int,tr,dfs,char,SDUT,ans,优化
From: https://www.cnblogs.com/zzh1206/p/17056304.html

相关文章

  • SDUT 简单的代码生成程序
    SDUT简单的代码生成程序Description通过三地址代码序列生成计算机的目标代码,在生成算法中,对寄存器的使用顺序为:寄存器中存有>空寄存器>内存中存有>以后不再使用......
  • iOS Swift圆角绘制与离屏渲染优化
    iOS里面使用圆角有可能造成离屏渲染,它需要开辟一个新的内存空间,做上下文切换(状态切换),并且渲染完成后还要进行拷贝操作,因此会造成一定的性能损耗,需要进行优化。1原理http......
  • 优化if...else...语句
    写代码的时候经常遇到这样的场景:根据某个字段值来进行不同的逻辑处理。例如,不同的会员等级在购物时有不同的折扣力度。如果会员的等级很多,那么代码中与之相关的if...elseif......
  • SQL 优化 20连问,建议收藏
    一、查询SQL尽量不要使用select*,而是具体字段1、反例SELECT * FROM user2、正例SELECT id,username,tel FROM user3、理由节省资源、减少网络开销。可能用......
  • sc stream-rabbit 优化版、绑定器-自定20230112
     一、生产者【2062】     1、pom.xml<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-star......
  • 为neovim优化语法高亮
    为neovim优化语法高亮neovim和vim在我用起来都有一个问题:代码高亮很烂于是我找到了一个插件:nvim-treesitter(后面发现semantichighlight也挺不错的),优化我的neovim的代码......
  • 利用chatGPT人工智能重构优化代码
    这个工具目前是免费的,能用多久不确定。https://chatgpt.sbaliyun.com/用法:在上面的文本框中输入问题,例如:能对它进行优化吗?然后说一下优化前后的差别。getIds(arr,id)......
  • 【转】FISCO BCOS中交易池及其优化策略
    FISCOBCOS区块链系统中,交易上链之前,均存储在交易池中。交易池是区块链小能手,一方面担任质检员的职务,将所有非法交易拒之门外;一方面担任供应商的职责,向共识模块输送合法交......
  • MySQL优化四,高性能优化
    一,查询优化器这个部分的整个过程是由MySQL的存储引擎来做的,优化器就会根据存储引擎来使用原来的开销,优化后的开销,哪个更好一点? 1.如果是查询语句(select语句),首先会查......
  • 【优化求解】基于遗传算法优化卸载策略附matlab代码
    ✅作者简介:热爱科研的Matlab仿真开发者,修心和技术同步精进,matlab项目合作可私信。......