题目链接

思路

看到n比较小,可以状压。

可以先考虑什么情况下会无法平衡。显然就是排完序之后两两相邻的不能满足小于等于c的限制。

状态。用f[i]来表示i集合中的鹿完成交换所需要的次数。

预处理。无法平衡的肯定就是INF。已经平衡的是0。其他的先暂设为k-1(k是i集合中鹿的个数)。

然后转移。每个集合可以由他的子集转移过来。即$$f[i]=min(f[i],f[j] + f[i \oplus j])$$

其中j为i的子集

代码

  1. /*
  2. * @Author: wxyww
  3. * @Date: 2019-01-19 14:17:57
  4. * @Last Modified time: 2019-01-19 14:30:13
  5. */
  6. #include<cstdio>
  7. #include<algorithm>
  8. #include<iostream>
  9. #include<cstdlib>
  10. #include<cmath>
  11. #include<ctime>
  12. #include<bitset>
  13. using namespace std;
  14. typedef long long ll;
  15. const int INF = 1e9 + 7,N = 100000 + 10;
  16. ll read() {
  17. ll x=0,f=1;char c=getchar();
  18. while(c<'0'||c>'9') {
  19. if(c=='-') f=-1;
  20. c=getchar();
  21. }
  22. while(c>='0'&&c<='9') {
  23. x=x*10+c-'0';
  24. c=getchar();
  25. }
  26. return x*f;
  27. }
  28. int n,c,tmp[N];
  29. int a[20],b[20],tt[100];
  30. int pd(int x) {
  31. int js = 0;
  32. int bz = 0;
  33. for(int i = 1;i <= n;++i) {
  34. if(1 << (i - 1) & x) {
  35. if(abs(a[i] - b[i]) > c) bz = 1;
  36. tt[++js] = a[i];
  37. tt[++js] = b[i];
  38. }
  39. }
  40. if(bz == 0) return 0;
  41. sort(tt + 1,tt + js + 1);
  42. for(int i = 1;i <= js;i += 2) {
  43. if(tt[i + 1] - tt[i] > c) return INF;
  44. }
  45. return js / 2 - 1;
  46. }
  47. int f[N];
  48. int main() {
  49. n = read(),c = read();
  50. for(int i = 1;i <= n;++i) a[i] = read(),b[i] = read();
  51. int K = (1 << n) - 1;
  52. if(pd(K) == INF) {
  53. puts("-1");
  54. return 0;
  55. }
  56. for(int i = 1;i <= K;++i) {
  57. f[i] = pd(i);
  58. }
  59. for(int i = 1;i <= K;++i) {
  60. for(int j = i;j > 0;j = (j - 1) & i) {
  61. f[i] = min(f[i],f[j] + f[i ^ j]);
  62. }
  63. }
  64. cout<<f[K];
  65. return 0;
  66. }

bzoj3900 交换茸角的更多相关文章

  1. bzoj千题计划240:bzoj3900: 交换茸角

    http://www.lydsy.com/JudgeOnline/problem.php?id=3900 dp[i]表示让状态为i的鹿满足要求的最少交换次数 不能枚举两头鹿交换,因为一头鹿可能交换多次 ...

  2. bzoj 3900: 交换茸角

    3900: 交换茸角 Description 动物园里有 n 头麋鹿.每头麋鹿有两支茸角,每支茸角有一个重量.然而,一旦某头麋鹿上 两支茸角的重量之差过大,这头麋鹿就会失去平衡摔倒.为了不然这种悲剧发 ...

  3. bzoj AC倒序

    Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...

  4. DP&图论 DAY 3 上午

    DP&图论  DAY 3  上午 状态压缩dp >状态压缩dp ◦状态压缩是设计dp状态的一种方式.◦当普通的dp状态维数很多(或者说维数与输入数据有关),但每一维总量很少是,可以将多维 ...

  5. 状态压缩dp相关

    状态压缩dp 状态压缩是设计dp状态的一种方式. 当普通的dp状态维数很多(或者说维数与输入数据有关),但每一维总 量很少是,可以将多维状态压缩为一维来记录. 这种题目最明显的特征就是: 都存在某一给 ...

  6. 状压dp(8.8上午)

    神马是状态压缩? 就是当普通dp的每一维表示的状态非常少的时候,可以压缩成一维来表示 如果m==8 dp[i][0/1][0/1]......[0/1] 压缩一下 dp[i][s]表示到了第i行,状态 ...

  7. DAY 3 上午

    状压DP 状态压缩dp 状态压缩是设计dp状态的一种方式. 当普通的dp状态维数很多(或者说维数与输入数据有关),但每一维总量很少时,可以将多维状态压缩为一维来记录. 这种题目最明显的特征就是:都存在 ...

  8. A Game of Thrones(1) - Bran

    The morning had dawned clear and cold, with a crispness(易碎:清新) that hinted(暗示:示意) at the end of summ ...

  9. 日常英语---十一、MapleStory/Monsters/Level 201-210(Dark Demon Eagle Rider)

    日常英语---十一.MapleStory/Monsters/Level 201-210(Dark Demon Eagle Rider) 一.总结 一句话总结:骑着鹰的快速飞行的恶魔,进入地图后跟着你. ...

随机推荐

  1. element-ui 源码解析 二

    Carousel 走马灯源码解析 1. 基本原理:页面切换 页面切换使用的是 transform 2D 转换和 transition 过渡 可以看出是采用内联样式来实现的 举个栗子 <div : ...

  2. mvn clean compile package install deploy

    (1) package 目的是打包,在pom中,如果是jar就会打包成jar,如果是war就会打包成war 在pom.xml中: <modelVersion></modelVersi ...

  3. Java多线程1:进程与线程的概念、区别和联系

    一.进程的的概念 引用线程之前进程的概念: 进程是表示资源分配的基本单位,也是调度运行的基本单位.例如,用户运行自己的程序,系统就创建一个进程,并为它分配资源,包括内存空间.磁盘空间.I/O设备等.然 ...

  4. 前端传送JSON数据,报Required request body is missing

    声明: 后端为Java,采用SSM框架 前端一个JSON.stringify()传来的json字符串,后端一般用@RequestBody标签来定义一个参数接收 但问题在于,当我使用get方式传JSON ...

  5. XCTF 4th-WHCTF-2017 creakme

    exe文件 运行一下 随便输一下 ps.这个曹操身边的故事挺有意思的 但是没啥卵用....... 查一下壳无壳 ida载入 发现找不到main函数 直接看start感觉逻辑乱乱的(萌新求不喷..... ...

  6. Lodop连续打印内容逐渐偏移怎么办

    Lodop打印控件中,可以使用打印机自带的纸张名称,也可以自定义纸张.(SET_PRINT_PAGESIZE语句).通常进行打印开发,为了避免浪费纸张,会用虚拟打印机效果作为依据,虚拟打印机连续打印多 ...

  7. Lodop的JS模版代码、文档式模版 生成加载赋值博文索引

    Lodop获取全部JS代码,传统JS模版的生成.LODOP设置打印设计返回JS代码是变量 LodopJS代码模版的加载和赋值 Lodop生成文档式模版 LodopJS文档式模版的加载和赋值 由于加载J ...

  8. ADO.NET工具类(一)

    using System; using System.Collections.Generic; using System.Text; using System.Data.SqlClient; usin ...

  9. 第213天:12个HTML和CSS必须知道的重点难点问题

    12个HTML和CSS必须知道的重点难点问题 这12个问题,基本上就是HTML和CSS基础中的重点个难点了,也是必须要弄清楚的基本问题,其中定位的绝对定位和相对定位到底相对什么定位?这个还是容易被忽视 ...

  10. [HAOI2007] 修筑绿化带

    类型:单调队列 传送门:>Here< 题意:给出一个$M*N$的矩阵,每一个代表这一格土地的肥沃程度.现在要求修建一个$C*D$的矩形花坛,矩形绿化带的面积为$A*B$,要求花坛被包裹在绿 ...