[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找到她并请他预言他的未来.这个精灵透过他的水 ...
随机推荐
- 基于Docker构建Jenkins CI平台
1.部署gitlab 1.1 部署gitlab docker run -d \ --name gitlab \ -p 8443:443 \ -p 9999:80 \ -p 9998:22 \ -v $ ...
- 定时器实现Promise.all()的简单使用
// 异步事件1 function time1() { const promise = new Promise(function (resolve, reject) { setTimeout(func ...
- Ubuntu开放对外端口
1.查看已经开启的端口 sudo ufw status 2.打开80端口 sudo ufw allow 80 3.防火墙开启 sudo ufw enable 4.防火墙重启 sudo ufw relo ...
- 使用springBoot和mybatis整合时出现如下错误:org.apache.ibatis.binding.BindingException: Invalid bound statement (not found)解决方案
在pom.xml文件中添加如下: <build> <resources> <resource> & ...
- 如何使用android-support-V7包中ActionBar(Eclipse版)
$*********************************************************************************************$ 博主推荐 ...
- Rubber Ducky简介
USB Rubber Ducky是一款模仿人工键盘输入的设备,外形和U盘一样,模拟键盘输入速度可达到1000个字符每分钟,并且适合任何操作系统,包括安卓等移动OS,它使用的是它特定的脚本语言,用记事本 ...
- robotframework 时间控件的操作的几种方法总结。
- 引入scss(@import)和其中易错点
1.引入文件方式 @import 'url'; ./ :当前目录 ../ :上级目录 src/api/styles: 绝对路径 2.一般在main.js中引用当做全局样式 import 'styles ...
- 20140729 while((*pa++=*pb++)!='\0') 合并数组代码 C++类型转换关键字 封装 多态 继承
1.关于while((*pa++=*pb++)!='\0')和while((*pa=*pb)!='\0') {pa++;pb++;}的不同 #include<stdio.h> void m ...
- docker容器的常见操作
进入容器 docker exec -it 12a022ee8127 /bin/bash 交互模式进入容器 docker exec -it 12a022ee8127 ip a 查看容器的ip等信息 批量 ...