hdu5890 bitset 优化dp
来源:互联网 发布:sas怎么导入excel数据 编辑:程序博客网 时间:2024/06/05 17:56
题意:50个数,10W个询问,每次问删掉第i,j,k个数后,是否存在一种选10个数和为87的方案,只需要输出 ’Yes’ 或者 ’No’
题解:暴力:不同的询问大概2W个,每个暴力bitset DP,抠一抠能卡着过。优化1:先求出一组解,如果询问和解没交就是’Yes’,否则暴力,不同的询问大概1W个;优化2:先预处理出所有询问的答案,能方便的复用之前的DP数组,不用每次从头开始重新求。
#include<bits/stdc++.h>using namespace std;#define ll long longconst int N=1e5+10,M=1e6+10,inf=1e9+10,mod=1e9+7;const ll INF=1e18+10;bitset<90>dp[11];int ans[60][60][60];int a[100],n,m;int q[5];int check(int x,int y,int z){ for(int i=0;i<=n;i++)dp[i].reset(); dp[0][0]=1; for(int i=1;i<=n;i++) { if(i!=x&&i!=y&&i!=z) for(int t=10;t>=1;t--) dp[t]|=dp[t-1]<<a[i]; } if(dp[10][87]==1) return 1; return 0;}int main(){ int T; scanf("%d",&T); while(T--) { memset(ans,0,sizeof(ans)); scanf("%d",&n); for(int i=1;i<=n;i++) scanf("%d",&a[i]); for(int i=1;i<=n;i++) for(int j=i;j<=n;j++) for(int k=j;k<=n;k++) if(check(i,j,k))ans[i][j][k]=1; scanf("%d",&m); while(m--) { for(int i=0;i<3;i++) scanf("%d",&q[i]); sort(q,q+3); if(ans[q[0]][q[1]][q[2]]) printf("Yes\n"); else printf("No\n"); } } return 0;}
0 0
- hdu5890 bitset优化dp
- hdu5890 bitset 优化dp
- hdu5890 bitset优化DP
- hdu5890 bitset优化0/1背包
- hdu5890 Eighty seven(背包+bitset优化)
- 2016 ACM/ICPC Asia Regional Qingdao hdu5890 Eighty seven(DP+bitset优化妙用)
- bzoj3687 -- bitset优化DP
- hdu 5745 dp+bitset优化
- hdu5036(概率dp+bitset优化)
- HDU 5745 dp, bitset优化
- hdu5890 Eighty seven(DP)
- HDU5890 Eighty seven (数位DP)
- hdu5890
- HDU 5890 Eighty seven(bitset优化dp)
- 51Nod 1532 DP + bitset 优化
- [BZOJ2687]简单题(dp+bitset优化)
- 【hdu5890】【bitset+dp】Eighty seven【每次从序列中删掉第i,j,k个数后,是否存在一种选10个数和为87的方案】
- hdu5890(二维01背包+bieset优化)
- Caffe: Data layer prefetch queue empty
- GCC中使用预编译头文件
- StoryBoard中默认勾选Adjust Scroll View Insets选项,导致导航条下方的控件看不到
- TableLayout指示器修改标签字体
- 网络TCP建立连接为什么需要三次握手而结束要四次
- hdu5890 bitset 优化dp
- 时间复杂性为O (n2),是什么意思
- EndNote的插件不在word中显示以及在word 2010中采用EndNote X7插入引用的方法
- nth-of-type(n)选择器
- BZOJ2085 [Poi2010]Hamsters
- 从零开始学习音视频编程技术(二) 音频格式讲解
- Oracle 密码文件
- java基础
- GDB 常用命令