最优二叉树II

最优二叉树II

https://www.nowcoder.com/questionTerminal/0d939e874a004f449a370aca1346dd5c?answerType=1&f=discussion

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;
}
全部评论

相关推荐

等闲_:小红书基本不区分日常和暑期,你是应届实习时间够了就有转正机会,只要部门有hc
点赞 评论 收藏
分享
2025-11-22 16:20
已编辑
用友_Java开发实习生(实习员工)
等闲_:感觉有好多地方会被问穿,mysql存储向量这个方案问题应该很大的,如果深问的的话,为什么不用es,不用pg,不用mivus,分块策略是怎么做的,向量化是怎么向量化的,稠密向量还是稀疏向量,再深问余弦相似度,HSWM算法,Bm25算法,为什么不用混合检索或者Rank重排序优化?其他的项目不停机分库分表咋实现的,切库过程中数据有diff的话有没有补偿策略?既然有了分库分表了有没有碰到业务上不好优化的慢sql,让这个sql读从库?而且点评的话,最好自己压测过,要不这个数据也不好解释。现在就27的情况来看,很多同学已经有了中大厂实习,这个节点也会偏向这些有大厂实习的92同学,而且hc也不多,所以坚持海投吧
听劝,我这个简历该怎么改...
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务