题目链接:https://cn.vjudge.net/contest/281960#problem/B

题目大意:中文题目

具体思路:

我们通过构造矩阵,

x , 3x,9x,27x

2x,6x,18x,54x

............

讲的很好的一篇博客:https://www.cnblogs.com/ljh2000-jump/p/6489018.html

可以看出,只要是选出的是相邻的,就一定是不满足的情况,所以说,我们可以通过构造矩阵将不满足的情况找出来,然后通过状压DP,通过不满足情况的筛选,将满足的情况找出来。

AC代码:

  1. #include<bits/stdc++.h>
  2. using namespace std;
  3. # define inf 0x3f3f3f3f
  4. # define ll long long
  5. const int maxn = 1e5+;
  6. const int mod = 1e9+;
  7. int vis[maxn];
  8. int a[][],n;
  9. int f[][maxn];
  10. int bin[],b[];
  11. int cal(int t)
  12. {
  13. memset(b,,sizeof(b));
  14. a[][]=t;
  15. for(int i=; i<=; i++)
  16. {
  17. if(a[i][]*<=n)
  18. {
  19. a[i+][]=a[i][]*;
  20. }
  21. else
  22. {
  23. a[i+][]=n+;
  24. }
  25. }
  26. for(int i=; i<=; i++)
  27. {
  28. for(int j=; j<=; j++)
  29. {
  30. if(a[i][j-]*<=n)
  31. {
  32. a[i][j]=a[i][j-]*;
  33. }
  34. else
  35. a[i][j]=n+;
  36. }
  37. }
  38. for(int i=; i<=; i++)
  39. {
  40. for(int j=; j<=; j++)
  41. {
  42. if(a[i][j]<=n)
  43. {
  44. b[i]+=bin[j-];
  45. vis[a[i][j]]=;
  46. }
  47. }
  48. }
  49. for(int i=; i<=; i++)
  50. {
  51. for(int j=; j<=b[i]; j++)
  52. {
  53. f[i][j]=;
  54. }
  55. }
  56. f[][]=;
  57. for(int i=; i<=; i++)
  58. {
  59. for(int j=; j<=b[i]; j++)
  60. {
  61. if(f[i][j])
  62. {
  63. for(int k=; k<=b[i+]; k++)
  64. {
  65. if(((j&k)==)&&(k&(k>>))==)
  66. {
  67. f[i+][k]=(f[i][j]+f[i+][k])%mod;
  68. }
  69. }
  70. }
  71. }
  72. }
  73. return f[][];
  74. }
  75. int main()
  76. {
  77. scanf("%d",&n);
  78. bin[]=;
  79. for(int i=; i<=; i++)
  80. {
  81. bin[i]=bin[i-]<<;
  82. }
  83. ll ans=;
  84. for(int i=; i<=n; i++)
  85. {
  86. if(vis[i])
  87. continue;
  88. ans=ans*cal(i)%mod;
  89. }
  90. printf("%lld\n",ans);
  91. return ;
  92. }

B - 集合选数 (状压DP)的更多相关文章

  1. 【BZOJ-2732】集合选数 状压DP (思路题)

    2734: [HNOI2012]集合选数 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1070  Solved: 623[Submit][Statu ...

  2. [HNOI2012]集合选数 --- 状压DP

    [HNOI2012]集合选数 题目描述 <集合论与图论>这门课程有一道作业题,要求同学们求出\({1,2,3,4,5}\)的所有满足以 下条件的子集:若 x 在该子集中,则 2x 和 3x ...

  3. 【BZOJ-2734】集合选数 状压DP (思路题)

    2734: [HNOI2012]集合选数 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1070  Solved: 623[Submit][Statu ...

  4. BZOJ 2734 [HNOI2012]集合选数 (状压DP、时间复杂度分析)

    题目链接 https://www.lydsy.com/JudgeOnline/problem.php?id=2734 题解 嗯早就想写的题,昨天因为某些不可告人的原因(大雾)把这题写了,今天再来写题解 ...

  5. 洛谷$P3226\ [HNOI2012]$集合选数 状压$dp$

    正解:$dp$ 解题报告: 传送门$QwQ$ 考虑列一个横坐标为比值为2的等比数列,纵坐标为比值为3的等比数列的表格.发现每个数要选就等价于它的上下左右不能选. 于是就是个状压$dp$板子了$QwQ$ ...

  6. $HNOI2012\ $ 集合选数 状压$dp$

    \(Des\) 求对于正整数\(n\leq 1e5\),{\(1,2,3,...,n\)}的满足约束条件:"若\(x\)在该子集中,则\(2x\)和\(3x\)不在该子集中."的子 ...

  7. bzoj 2734: [HNOI2012]集合选数 状压DP

    2734: [HNOI2012]集合选数 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 560  Solved: 321[Submit][Status ...

  8. bzoj 2734 [HNOI2012]集合选数 状压DP+预处理

    这道题很神啊…… 神爆了…… 思路大家应该看别的博客已经知道了,但大部分用的插头DP.我加了预处理,没用插头DP,一行一行来,速度还挺快. #include <cstdio> #inclu ...

  9. 【BZOJ5010】【FJOI2017】矩阵填数 [状压DP]

    矩阵填数 Time Limit: 10 Sec  Memory Limit: 128 MB[Submit][Status][Discuss] Description 给定一个 h*w 的矩阵,矩阵的行 ...

  10. HDU 1565 方格取数 状压dp

    题目: 给你一个n*n的格子的棋盘,每个格子里面有一个非负数. 从中取出若干个数,使得任意的两个数所在的格子没有公共边,就是说所取的数所在的2个格子不能相邻,并且取出的数的和最大. Input 包括多 ...

随机推荐

  1. 学习笔记之csrf

    CBV 添加 csrf 第一种: 指定方法方面添加 装饰器 @memethod_decorator(xxx) 第二种 全部添加: 注意 在类名前: @method_decorator(xxx,name ...

  2. ajax 提交数组 泛型集合(二)

    最近在项目中,使用 mvc架构,model层使用code first 碰见一个问题,前台json传递数据给后台action的复杂对象,发现复杂对象中的list范型集合并没有获取到数据. 研究半天,终于 ...

  3. 有源汇有上下界最小流 DInic + 各种优化 模板

    例题:loj117 : https://loj.ac/problem/117 //其实就是判断可行流后倒着求一遍最大流 #include <iostream> #include <c ...

  4. Sublime text3 插件LiveReload 实现实时预览

    1.首先要安装插件LiveReload Sublime text3. 菜单 preferences->packages control,输入install.. 回车,输入LiveReload回车 ...

  5. LOJ #2434. 「ZJOI2018」历史(LCT)

    题意 click here 题解 我们首先考虑答案是个什么样的东西, 不难 发现每个点可以单独计算它的贡献. 令每个点 \(i\) 崛起次数为 \(a_i\) . 假设一个点子树的 \(\sum a_ ...

  6. uoj233/BZOJ4654/洛谷P1721 [Noi2016]国王饮水记 【dp + 斜率优化】

    题目链接 uoj233 题解 下面不加证明地给出几个性质: 小于\(h[1]\)的城市一定是没用的 任何城市联通包含\(1\)且只和\(1\)联通一次 联通顺序从小到大最优 单个联通比多个一起联通要优 ...

  7. c++ io标准库2

    转自:http://www.2cto.com/kf/201110/109445.html 接下来我们来学习一下串流类的基础知识,什么叫串流类? 简单的理解就是能够控制字符串类型对象进行输入输出的类,C ...

  8. 灯 & 树

    这回是两道题一起... [USACO09NOV]灯 [中山市选2009]树 题意:给您一些灯,以及一些边.每次改变一盏灯的时候,它相邻的灯也会变.求把灯状态全部转换的最小操作次数. 解: 解异或方程组 ...

  9. Python基础-简介一

    一.Python介绍 1. Python的应用领域及流行程度 python的创始人为吉多·范罗苏姆(Guido van Rossum).1989年的圣诞节期间,吉多·范罗苏姆为了在阿姆斯特丹打发时间, ...

  10. 代码实战之AdaBoost

    尝试用sklearn进行adaboost实战 & SAMME.R算法流程,博客地址 初试AdaBoost SAMME.R算法流程 sklearn之AdaBoostClassifier类 完整实 ...