分析
NOIP2017TG背景。。。
那个位运算式子相信都知道是a+b>>1吧
然后最早想的区间DP,是对的
(可我算时间会爆炸?玄学时间复杂度O(能过))
设f[l][r][k]表示l~r能否合成k
转移显然(我错了),枚举断点和a,b就行
#include <iostream> #include <cstdio> #include <algorithm> using namespace std; const int N=160; int n; int a[N],f[N][N][8],ans[N]; int main() { freopen("math.in","r",stdin); freopen("math.out","w",stdout); scanf("%d",&n); for (int i=1;i<=n;i++) scanf("%d",&a[i]),f[i][i][a[i]]=1; for (int len=2;len<=n;len++) for (int l=1;l<=n-len+1;l++) { int r=l+len-1; for (int i=l;i<=r;i++) for (int a1=0;a1<8;a1++) for (int a2=0;a2<8;a2++) f[l][r][a1+a2>>1]|=f[l][i][a1]&f[i+1][r][a2]; } for (int i=0;i<8;i++) if (f[1][n][i]) printf("%d ",i); }