[ABC318D] General Weighted Max Matching 题解

因为 n 很小,所以考虑状压 dp。

sta 为一个二进制整数,表示当前第 i 个点有没有被匹配。

那么显然对于每一个 stai,j 两点未被匹配的都可以用边 (i,j) 来转移,即 dpsta{i,j}dpsta+wi,j

时间复杂度 O(2n×n(n1)2),极限数据中 n(n1)2=120,因此可以通过本题。

#include <cstdio> #include <algorithm> typedef long long ll; const int N=(1<<16)-1; int n; int d[17][17]; ll dp[N+5],ans; int main() { scanf("%d",&n); for(int i=0;i<n;i++) { for(int j=i+1;j<n;j++) scanf("%d",&d[i][j]); } for(int sta=0;sta<=(1<<n)-1;sta++) {//枚举状态 for(int i=0;i<n;i++) { if((sta>>i)&1) continue;//判断合法性 for(int j=i+1;j<n;j++) { if((sta>>j)&1) continue;//判断合法性 dp[sta|(1<<i)|(1<<j)]=std::max(dp[sta|(1<<i)|(1<<j)],dp[sta]+d[i][j]);//转移 ans=std::max(ans,dp[sta|(1<<i)|(1<<j)]); } } } printf("%lld\n",ans); return 0; }

__EOF__

本文作者Scorilon
本文链接https://www.cnblogs.com/Scorilon/p/17674706.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角推荐一下。您的鼓励是博主的最大动力!
posted @   Scorilon  阅读(115)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 提示词工程——AI应用必不可少的技术
· .NET周刊【3月第1期 2025-03-02】
点击右上角即可分享
微信分享提示