【学习笔记】拟阵

在这里插入图片描述
对于这一类问题,有统一的解决方法,即 按照权值从大到小贪心 ,直到不能选为止。

常见的拟阵模型:

  • 物品有 ( v i , w i ) (v_i,w_i) (vi,wi) 两个属性,选出一个集合 S S S ,求 max ⁡ ( ∑ i ∈ S v i ) \max(\sum_{i\in S}v_i) max(iSvi) ,其中 S S S 的任意非空子集属性异或和 ≠ 0 \neq 0 =0

M(E,I) 中 E 表示 n 个物品组成的集合, I 表示满足任意非空子集属性和 ≠ 0 \neq 0 =0 的物品集合。

  • MST 。

M(E,I) 中 E 表示边的集合, I 表示满足没有环的边的集合。

因为求的是 MST ,所以考虑 w ( u , v ) = w 0 − w ( u , v ) w(u,v)=w_0-w(u,v) w(u,v)=w0w(u,v) ,注意我们求的必须是一个生成树,所以需要避免边的权值为负 。(否则可以选择不选)。

  • 最小基环生成树 。

证明略。同样是按边排序贪心,证明可以反证(拟阵的证明过程比较麻烦)。

  • n n n 个向量 ( a 1 , a 2 , . . , a m ) (a_1,a_2,..,a_m) (a1,a2,..,am) ,每个向量有权值 v a l i val_i vali ,选出线性无关的向量集合 S ,在满足 |S| 最大的前提下求 min ⁡ ( ∑ i ∈ S v a l i ) \min(\sum_{i\in S}val_i) min(iSvali)

这题可以转化为求 max ⁡ ( ∑ i ∈ S v a l i ) \max(\sum_{i\in S}val_i) max(iSvali) ,因为权值为正,所以 S 一定是原拟阵的基,又因为拟阵的基大小相同(否则与交换性矛盾),所以直接把 v a l i val_i vali 从小到大排序贪心即可。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值