博客
关于我
10.16多校连测
阅读量:270 次
发布时间:2019-03-01

本文共 944 字,大约阅读时间需要 3 分钟。

T1

题意简述

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

题解

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

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

T2

题意简述

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

题解

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

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

T3

题意简述

有一些物品,要装到 k k k个行李中,现在有一个操作,每个行李 + k &VeryThinSpace; m o d &VeryThinSpace; p +k\bmod{p} +kmodp 0 ≤ k &lt; p 0\leq k&lt;p 0k<p,求最重的行李最轻的重量。

题解

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

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

转载地址:http://ebwo.baihongyu.com/

你可能感兴趣的文章
mysql报错级别_更改MySQL日志错误级别记录非法登陆(Access denied)
查看>>
Mysql报错:too many connections
查看>>
MySQL报错:无法启动MySQL服务
查看>>
mysql授权用户,创建用户名密码,授权单个数据库,授权多个数据库
查看>>
mysql排序查询
查看>>
MySQL排序的艺术:你真的懂 Order By吗?
查看>>
MySQL排序的艺术:你真的懂 Order By吗?
查看>>
Mysql推荐书籍
查看>>
Mysql插入数据从指定选项中随机选择、插入时间从指定范围随机生成、Navicat使用存储过程模拟插入测试数据
查看>>
MYSQL搜索引擎
查看>>
mysql操作数据表的命令_MySQL数据表操作命令
查看>>
mysql操作日志记录查询_如何使用SpringBoot AOP 记录操作日志、异常日志?
查看>>
MySQL支持的事务隔离级别,以及悲观锁和乐观锁的原理和应用场景?
查看>>
mysql支持表情
查看>>
MySQL支撑百万级流量高并发的网站部署详解
查看>>
MySQL改动rootpassword的多种方法
查看>>
mysql数据分组索引_MYSQL之索引配置方法分类
查看>>
mysql数据取差,mysql屏蔽主外键关联关系
查看>>
MySQL数据和Redis缓存一致性方案详解
查看>>
MySQL数据和Redis缓存一致性方案详解
查看>>