[JZOJ 5600] Arg
题意:求最少LIS覆盖...
思路:
计算\(LIS\)时我们一般用\(dp\)表示到当先位置时以当前位置结尾的\(LIS\)最长长度。
那么这个数组保证单调不降,我们考虑二进制表示。
然后就是转移了...
不过蜜汁\(RE\)啊,自测能过...
#include <bits/stdc++.h>
using namespace std;
inline int read(){
int q=0,f=1;char ch = getchar();
while(!isdigit(ch)){
if(ch=='-')f=-1;ch=getchar();
}
while(isdigit(ch)){
q = q * 10 + ch - '0';
ch = getchar();
}
return q*f;
}
int n;
int ans;
int f[20010000];
int c[20];int m;
int wtf[20];
int a[20];
int c2[20];
inline void dfs(int x,int lim,int k) {
if(x > n) {
if(!lim) ans += f[k];
return;
}
k += c[x - 1];
dfs(x + 1,lim,k);
k += c[x - 1];
dfs(x + 1,lim - 1,k);
}
int main () {
freopen("Arg.in","r",stdin);
freopen("Arg.out","w",stdout);
scanf("%d %d",&n,&m);
for(int i = 1;i <= m; ++i) {
scanf("%d",&a[i]);
}
c[0] = c2[0] = 1;
for(int i = 1;i <= n; ++i) {
c[i] = c[i - 1] * 3;
c2[i] = c2[i - 1] * 2;
}
f[0] = 1;
for(int i = 0;i <= c2[n] - 2; ++i) {
bool ok = 1;
bool tag = 1;
for(int j = 1;j <= m; ++j) {
if((i & c2[a[j] - 1]) == 0) {
ok = 0;
}
else if(!ok) {
tag = 0;
break;
}
}
if(tag) {
for(int ii = i;1;ii = (ii - 1) & i) {
int v = 0;
for(int j = 1;j <= n; ++j) {
if(ii & c2[j - 1]) v += c[j - 1];
if(i & c2[j - 1]) v += c[j - 1];
}
if(f[v]) {
for(int j = 1;j <= n; ++j) {
if(v / c[j - 1] % 3 == 0) {
int V = v + 2 * c[j - 1];
for(int k = j + 1;k <= n; ++k) {
if(V / c[k - 1] % 3 == 2) {
V -= c[k - 1];
break;
}
}
f[V] += f[v];
}
}
}
if(ii == 0) break;
}
}
}
dfs(1,m,0);
printf("%d\n",ans);
return 0;
}
[JZOJ 5600] Arg的更多相关文章
- QString::arg的用法
1.用法示例1 String str = QString("%1 %2 %3 %4 %5 %6 %7 %8 %9 %10 %11").arg("1"," ...
- T2 Func<in T1,out T2>(T1 arg)
委托调用方法的4种方式. using System; using System.Collections.Generic; namespace ConsoleApplication1 { delegat ...
- rabbitmq inequivalent arg 'x-message-ttl' for queue 'QUEUE_NAME' in vhost '/'异常解决
中午调整了一台应用服务的mq ttl参数后,重启时出现如下异常: Caused by: com.rabbitmq.client.AlreadyClosedException: channel is a ...
- 关于QString中的arg()函数使用方法
例:正确做法:ui->label->setText(QString("Processingfile%1").arg(index));错误做法: ui->label ...
- public static void main(String arg[])
该语句定义了main方法. main方法是程序执行的入口,所有的java程序都必须具备一个main()方法,而且必须按照如上的格式来定义. 不具有main方法的类可以编译,但不能执行.因为它没有m ...
- chr()、unichr()和ord(),全半角转换,ValueError: unichr() arg not in range() (wide Python build)
chr().unichr()和ord() chr()函数用一个范围在range(256)内的(就是0-255)整数作参数,返回一个对应的字符. unichr()跟它一样,只不过返回的是 Unicode ...
- 压缩感知中的数学知识:稀疏、范数、符号arg min
转自:http://blog.csdn.net/jbb0523/article/details/40262629 1.稀疏:什么是K稀疏呢? 在压缩感知里经常提到 "K稀疏" 的概 ...
- (jzoj snow的追寻)线段树维护树的直径
jzoj snow的追寻 DFS序上搞 合并暴力和,记录最长链和当前最远点,距离跑LCA # include <stdio.h> # include <stdlib.h> # ...
- [jzoj]3506.【NOIP2013模拟11.4A组】善良的精灵(fairy)(深度优先生成树)
Link https://jzoj.net/senior/#main/show/3506 Description 从前有一个善良的精灵. 一天,一个年轻人B找到她并请他预言他的未来.这个精灵透过他的水 ...
随机推荐
- qemu源码分析
参考:http://lists.gnu.org/archive/html/qemu-devel/2011-04/pdfhC5rVdz7U8.pdf 1. qemu与Bochs的区别: 1. Bochs ...
- 【小知识】神经网络中的SGD优化器和MSE损失函数
今天来讲下之前发的一篇极其简单的搭建网络的博客里的一些细节 (前文传送门) 之前的那个文章中,用Pytorch搭建优化器的代码如下: # 设置优化器 optimzer = torch.optim.SG ...
- 51-Ubuntu-打包压缩-1-打包压缩简介
打包压缩是日常工作中备份文件的一种方式 在不同操作系统中,常用的打包压缩方式是不同的 Windows 常用 rar Mac 常用 zip Linux 常用 tar.gz
- 我的vscode配置 利用Settings Sync一键安装
{ "prettier.eslintIntegration": true, // 点击保存时,根据 eslint 规则自定修复,同时集成 prettier 到 eslint 中 & ...
- Thread相关API
参考书籍:<java多线程核心编程技术> Thread相关API,这些API可以改变线程对象的状态 新建一个线程对象,调用start方法后,系统会为该线程分配CPU资源,此时该线程处于可运 ...
- UIPageViewController看这篇就够了
先说初始化 - (UIPageViewController *)PageViewController{ if(!_PageViewController){ //书脊位置,只有在UIPageViewCo ...
- runtime机制
runtime(简称运行时),是一套 纯C(C和汇编写的) 的API.而 OC 就是运行时机制,也就是在运行时候的一些机制,其中最主要的是消息机制. 消息机制原理:对象根据方法编号SEL去映射表查找对 ...
- NFS 服务器的配置
1. 安装 NFS 服务器 [root@localhost btools]#rpm -q nfs-utils 如果没有安装,从对应 Linux 操作系统版本的安装光盘上找到 nfs-utils 的安装 ...
- 2019_7_31python
练习 输入三条边长如果能构成三角形就计算周长和面积 import math a,b,c = input().split(',') a = float(a) b = float(b) c = floa ...
- API 数据缓存(本地缓存)