Sereja and Sets

我们先考虑对于一堆线段我们怎么求最大的不相交的线段数量。

我们先按 r 排序, 然后能选就选。

所以我们能想到我们用$dp[ i ][ j ]$表示已经选了 i 个线段, 最后一个被选的线段的右端点是 j 的方案数。

对于dp[ i ][ j ] -> dp[ i + 1 ][ k ], 所有能满足左端点 > j 右端点为 k 的方案数为1 << (k - j)种, 其他可以随意

放上取的方案数为1 << ( ( n - z ) * ( z - j ) )种, 所以可以得到

dp[ i + 1 ][ z ] += dp[ i ][ j ] * pow2[ (n - z) * (z - j) ] % mod * (pow2[ z - j ] - 1)

#include<bits/stdc++.h>
#define LL long long
#define LD long double
#define fi first
#define se second
#define mk make_pair
#define PLL pair<LL, LL>
#define PLI pair<LL, int>
#define PII pair<int, int>
#define SZ(x) ((int)x.size())
#define ull unsigned long long using namespace std; const int N = + ;
const int inf = 0x3f3f3f3f;
const LL INF = 0x3f3f3f3f3f3f3f3f;
const int mod = 1e9 + ;
const double eps = 1e-;
const double PI = acos(-); template<class T, class S> inline void add(T& a, S b) {
a += b; if(a >= mod) a -= mod;
}
template<class T, class S> inline void sub(T& a, S b) {
a -= b; if(a < ) a += mod;
}
template<class T, class S> inline bool chkmax(T& a, S b) {
return a < b ? a = b, true : false;
}
template<class T, class S> inline bool chkmin(T& a, S b) {
return a > b ? a = b, true : false;
} int n, k;
int dp[N][N];
int pow2[N * N]; int main() {
for(int i = pow2[] = ; i < N * N; i++)
pow2[i] = 1LL * pow2[i - ] * % mod;
scanf("%d%d", &n, &k);
dp[][] = ;
for(int i = ; i < k; i++) {
for(int j = ; j <= n; j++) {
if(!dp[i][j]) continue;
for(int z = j + ; z <= n; z++) {
add(dp[i + ][z], 1LL * dp[i][j] * pow2[(n - z) * (z - j)] % mod * (pow2[z - j] - ) % mod);
}
}
}
int ans = ;
for(int i = ; i <= n; i++)
add(ans, dp[k][i]);
printf("%d\n", ans);
return ;
} /*
*/

最新文章

  1. ECMAScript严格模式简介
  2. apache 配置https
  3. mysql概要(九)字符集和校对集
  4. Qt 读取txt文件乱码的解决办法
  5. BMVC reading list
  6. 14.3.5.3 How to Minimize and Handle Deadlocks 如何减少和处理死锁
  7. hibernate--coreapi--configuration sessionfactory--getcurrentsession--opensession
  8. Android通知Notification全面剖析
  9. [ExtJS5学习笔记]第九节 Extjs5的mvc与mvvm框架结构简介
  10. 2.5配置的框架浅析「深入浅出ASP.NET Core系列」
  11. H5(ionic2+VScode) 环境安装
  12. emwin 存在多个窗口时,如何获取当前所在窗口
  13. 前端下载excel打不开求助+解法
  14. this 相关
  15. Envoy 代替nginx https://www.jianshu.com/p/0a1f67b42fdb
  16. JavaBasic_07
  17. django之content_type
  18. MySQL性能分析和优化
  19. DOS批处理 - 函数教程
  20. Python开发【数据结构】:基础

热门文章

  1. $Django content_type组件 缓存组件
  2. 查询每个分组中第N的一条记录
  3. springcloud-3:required a bean of type 'com.netflix.discovery.DiscoveryClient' that could not be found.
  4. MR1和MR2(Yarn)工作原理流程
  5. [C]*和&amp;
  6. CXF使用
  7. Codeforces 1097G Vladislav and a Great Legend [树形DP,斯特林数]
  8. 使用 mod_rewrite 来修改 Confluence 6 的 URLs
  9. Confluence 6 管理员联系表单的后台配置界面
  10. Confluence 6 禁用管理员联系表单