10.16多校连测

T1

题意简述

给出一个集合,都有权值,求可以被分割成权值和相等的两份的子集个数。

题解

f[i][S]f[i][S]f[i][S]表示搜索到前iii个,SSS是一个3进制状态,0表示没有被选中,1表示被第一个集合选中了,2表示被第二个集合选中了,fff是第一个集合与第二个的差值,如果差值为0说明是两个相等的子集。这样做显然是O(3n)O(3^n)O(3n),会TLE。(这个我测的时候是想到了的)

考虑meet in the middle,O(3n/2)O(3^{n/2})O(3n/2)枚举左边,O(3n/2)O(3^{n/2})O(3n/2)枚举右边,和在一起是很好判断的。

T2

题意简述

给出一个排列PPP,定义一个排列a是好排列,当且仅当依次交换排列Q=1,2,3,⋯ ,nQ={1,2,3,\cdots,n}Q=1,2,3,,nai,ai+1a_i,a_{i}+1ai,ai+1两位,能得到排列PPP,求好排列的个数。

题解

题目等价于:给出一些例如iiii+1i+1i+1的前/后面的限制条件,问满足限制的排列个数。(这个我还是想到了的)

这个用一个dp就可以解决。

T3

题意简述

有一些物品,要装到kkk个行李中,现在有一个操作,每个行李+k&VeryThinSpace;mod&VeryThinSpace;p+k\bmod{p}+kmodp0≤k&lt;p0\leq k&lt;p0k<p,求最重的行李最轻的重量。

题解

枚举kkk,二分答案,时间复杂度O(n2log⁡n)O(n^2\log n)O(n2logn)会TLE(这个我还是想到了)

random_shuffle一下kkk可能的取值,每次先判一下这个kkk的取值可不可能使答案更优,时间复杂度是期望O(nP+nlog⁡nlog⁡P)O(nP+n\log n\log P)O(nP+nlognlogP)

转载于:https://www.cnblogs.com/Canopus-wym/p/10376134.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值