分治

最优二叉树II

https://www.nowcoder.com/questionTerminal/0d939e874a004f449a370aca1346dd5c

图片说明
如图,该题是美团2021春招笔试题。当时做卷子想复杂了,觉着一个中序序列构建的树有多种可能,每种可能都得计算出开销,同时记录下最小开销。直接爆炸。后来看题解才觉悟是一个经典的分治问题

#include<bits/stdc++.h>
using namespace std;
const int maxn = 310;
const int inf = 1<<30;

vector<int>v(maxn,0);
//备忘录
int vis[maxn][maxn][maxn];
//以father为根节点能够得到的最优树
int dp(int l,int r, int father){
    if(l>r) return 0;
    if(vis[l][r][father]!=-1) return vis[l][r][father];
    int ret = inf;
    // 这些节点中每个均可能做根 需要遍历一下
    for(int i=l;i<=r;++i){
        //递归计算左右子树的最小代价
        int left = dp(l,i-1,i);
        int right = dp(i+1,r,i);
        // 总最小=min(左子树+右子树+选出的根节点值*father节点值)
        ret = min(ret,left+right+v[i]*v[father]);
    }
    //备忘录记下已经取得的值
    return vis[l][r][father]=ret;
}
int main(){
    int n;
    cin>>n;
    for(int i=1;i<=n;++i) cin>>v[i];
    memset(vis,-1,sizeof(vis));
    int ans = dp(1,n,0);
    printf("%d\n",ans);
    return 0;
}
全部评论
min(ret,left+right+v[i]*v[father]); 为什么是v[i]*v[father]啊
1 回复 分享
发布于 2021-03-16 11:58

相关推荐

04-30 15:51
已编辑
上海交通大学 机械工程师
点赞 评论 收藏
分享
野猪不是猪🐗:现在的环境就是这样,供远大于求。 以前卡学历,现在最高学历不够卡了,还要卡第一学历。 还是不够筛,于是还要求得有实习、不能有gap等等... 可能这个岗位总共就一个hc,筛到最后还是有十几个人满足这些要求。他们都非常优秀,各方面都很棒。 那没办法了,看那个顺眼选哪个呗。 很残酷,也很现实
点赞 评论 收藏
分享
挣K存W养DOG:我记得好多人说这个公司就是白嫖方案的,现在有大体方案要让你给他展示实现细节了,也是无敌了
点赞 评论 收藏
分享
评论
8
1
分享

创作者周榜

更多
牛客网
牛客企业服务