【Codeforces】CF 165 E Compatible Numbers(状压dp)

题目

传送门:QWQ

分析

很难想到方向,但有方向了就很easy了。

我们如何减少不必要的计算?

如果我们知道了$ 100111 $的相容的数,$ 100101 $的相容数和他是完全一样的。

我们就靠着这个思想写一下就行了。

注意位运算优先级。

代码

 1 #include <bits/stdc++.h>
 2 using namespace std;
 3 const int maxn=1<<22, INF=(1<<22)-1;
 4
 5 int dp[maxn], a[maxn];
 6
 7 int main(){
 8     int n;
 9     scanf("%d", &n);
10     for(int i=1; i<=n; i++)
11         scanf("%d", &a[i]);
12
13     memset(dp,-1,sizeof(dp));
14     for(int i=1;i<=n;i++){
15         dp[INF&(~a[i])]=a[i];
16     //    printf("%d %d\n", INF&(~a[i]),a[i]);
17     }
18     for(int i=INF; i>=1; i--) {
19         if(dp[i]>0) continue;
20         for(int j=0;j<22;j++) {
21             if(!(i &(1<<j)) && dp[i|(1<<j)]>0) {
22                 dp[i]=dp[i|(1<<j)];    //printf("----  %d %d   %d %d\n",i,j,a[i] &(1<<j),dp[a[i]&(1<<j)]);
23                 break;
24             }
25         }
26     }
27     for(int i=1;i<=n;i++)
28         printf("%d ",dp[a[i]]);
29     return 0;
30 }

原文地址:https://www.cnblogs.com/noblex/p/9527335.html

时间: 2024-10-13 01:45:17

【Codeforces】CF 165 E Compatible Numbers(状压dp)的相关文章

codeforces 342D Xenia and Dominoes(状压dp+容斥)

转载请注明出处: http://www.cnblogs.com/fraud/          ——by fraud D. Xenia and Dominoes Xenia likes puzzles very much. She is especially fond of the puzzles that consist of domino pieces. Look at the picture that shows one of such puzzles. A puzzle is a 3 ×

Codeforces 678E:Another Sith Tournament 状压DP

odd-even number 题目链接: http://codeforces.com/problemset/problem/678/E 题意: 有n个人打擂台赛,每两个人间都有相对的胜率,主角可以操控比赛顺序,求主角最后获胜的最大概率. 题解: 设dp[i][j]为状态 i (二进制位代表出场选手) j 号选手第一个上场时主角的最大胜率,dp[1][0]=1.0(场上只有主角一个人主角必胜). 状态转移方程dp[i][j]=max(dp[i][j],dp[i^(1<<j)][k]*p[k][

Codeforces 580D Kefa and Dishes(状压DP)

题目大概说要吃掉n个食物里m个,吃掉各个食物都会得到一定的满意度,有些食物如果在某些食物之后吃还会增加满意度,问怎么吃满意度最高. dp[S][i]表示已经吃掉的食物集合是S且刚吃的是第i个食物的最大满意度 ..没什么好说的 1 #include<cstdio> 2 #include<algorithm> 3 using namespace std; 4 5 int val[18],pairs[18][18]; 6 long long d[1<<18][18]; 7 8

CodeForces 385 D.Bear and Floodlight 状压DP

枚举灯的所有可能状态(亮或者不亮)(1<<20)最多可能的情况有1048576种 dp[i]表示 i 状态时灯所能照射到的最远距离(i 的二进制中如果第j位为0,则表示第j个灯不亮,否则就是亮) 当i&(1<< j)时代表第i个状态灯j不亮,此时可由状态i转移到状态 i ^ ( 1 << j) 即dp[(i^(1<<j))]=max(dp[(i^(1<<j))],get(dp[i],j)) get是从dp[i]的位置开始第j个灯所能照亮的

CF449D Jzzhu and Numbers (状压DP+容斥)

题目大意: 给出一个长度为n的序列,构造出一个序列使得它们的位与和为0,求方案数 也就是从序列里面选出一个非空子集使这些数按位与起来为0. 看了好久才明白题解在干嘛,我们先要表示出两两组合位与和为0的所有情况 先hx一下每个数出现的次数,然后我们从遍历 i ,i 是二进制的数位 然后遍历所有的情况,如果第 i 位有1,那么说明我们去掉第 i 位的1就是又一种情况! 其实我们统计的是所有数在删掉/不删掉每一位的1 所有可能出现的数! 那么,状态内任意组合,不能取空集,总数就是 再根据容斥原理(最玄

Codeforces Gym 100610 Problem K. Kitchen Robot 状压DP

Problem K. Kitchen Robot Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/gym/100610 Description Robots are becoming more and more popular. They are used nowadays not only in manufacturing plants, but also at home. One programmer wit

COdeforces#417D Cunning Gena(状压DP)

A boy named Gena really wants to get to the "Russian Code Cup" finals, or at least get a t-shirt. But the offered problems are too complex, so he made an arrangement with his n friends that they will solve the problems for him. The participants

Codeforces Gym 100676G Training Camp 状压dp

http://codeforces.com/gym/100676 题目大意是告诉你要修n门课,每门课有一个权值w[i], 在第k天修该课程讲获得k*w[i]的学习点数,给出了课程与先修课程的关系,要修该课程必须修完先修课程.问最多能学到多少点数. 非常简单的一道状压dp(一开始我还误导队友写成两维的去了 T^T); dp[s] : s 的二进制存放的是已经选择的课程,在该状态下的能获得的最大的点数. 这时如果再学一门课程k,将转移到状态ss (s | (1 << k) ) ,能否转移需要判断合

CodeForces 21D Traveling Graph 状压dp+欧拉回路

题目链接:点击打开链接 题意: 给定n个点m条边的无向图 求从1点开始经过每条边至少一次最后回到1点的最小路程 显然就是找一条路径可重复的欧拉回路 思路: 首先对于欧拉回路的结论是:所有点的度数都为偶数 因为所有边至少经过一次,那么可以把题意转换成加最少多少条边使得图满足以上结论 而加的边目的是为了把奇度数转成偶度数,先floyd一下得到任意点间加边的最小花费 dp[i]表示状态i下度数都为偶数的最小花费. 状压dp,把i状态下,所有未选择的点中挑2个奇度数的转移即可. #include <cs