acgo题库
  • 首页
  • 题库
  • 学习
  • 天梯
  • 备赛

    竞赛

    • CSP-J/S
    • 蓝桥杯

    考级

    • GESP
    • CPA
    • 电子学会考级
  • 竞赛
  • 讨论
  • 团队
登录
注册
题目详情提交记录(0)
  • 很简单但是繁杂的一道题

    userId_undefined

    Xylophone

    时间刺客空间掌握者时空双修者荣耀黄金CSP-J一等奖
    16阅读
    0回复
    0点赞
  • 题解

    #include<bits/stdc++.h> using namespace std; int n,m,W,fa[10001],dp[10001],w[10001],v[10001],cnt,neww[10001],newv[10001]; int find(int x){ return fa[x]=xfa[x]?x:find(fa[x]); } int main(){ cin>>n>>m>>W; for(int i=1;i<=n;++i) scanf("%d%d",&w[i],&v[i]); for(int i=1;i<=n;++i)fa[i]=i; for(int i=1;i<=m;++i){ int x,y; scanf("%d%d",&x,&y); int xx=find(x),yy=find(y); fa[xx]=yy; } for(int i=1;i<=n;++i){ int tmp=find(i); if(tmpi){ neww[i]+=w[i]; newv[i]+=v[i]; } else{ neww[tmp]+=w[i]; newv[tmp]+=v[i]; } } memset(w,0,sizeof(w)); memset(v,0,sizeof(v)); for(int i=1;i<=n;++i){ if(neww[i]!=0&&newv[i]!=0){ w[++cnt]=neww[i]; v[cnt]=newv[i]; } } for(int i=1;i<=cnt;++i) for(int j=W;j>=w[i];--j) dp[j]=max(dp[j],dp[j-w[i]]+v[i]); cout<<dp[W]; return 0; }

    userId_undefined

    ༺ཌༀ༒☯∞复仇者∞☯༒ༀད༻™

    题解仙人8月全勤卷王出道萌新时空双修者
    0阅读
    0回复
    0点赞
暂无数据

提交答案之后,这里将显示提交结果~

首页