造序列(构造,DP)
题面
Sample Input
7
8
7
10
31
20
100
869120
Sample Output
6
1 1 4 5 1 4
7
1 9 1 9 8 1 0
8
1 9 4 9 1 0 0 1
8
1 9 2 6 0 8 1 7
9
9 7 3 6 5 8 4 1 2
10
0 5 9 3 6 1 4 2 7 8
72
47 45 28 9 41 50 33 61 27 15 38 54 52 22 57 7 30 12 46 21 19 8 71 20 23 6 18 26 17 39 4 53 44 3 31 68 29 42 62 37 69 67 40 65 2 55 36 35 11 49 24 25 43 48 0 1 16 10 70 66 64 32 5 51 60 63 58 56 59 13 14 34
题解
首先我们想想对于一个序列怎么算它的上升子序列个数。我们一般会用 DP ,
d
p
[
i
]
dp[i]
dp[i] 表示以 i 结尾的上升子序列个数,那么
d
p
[
i
]
=
∑
j
=
0
i
−
1
[
a
j
<
a
i
]
d
p
[
j
]
,
d
p
[
0
]
=
1
dp[i]=\sum_{j=0}^{i-1}[a_j<a_i]dp[j]\;,dp[0]=1
dp[i]=∑j=0i−1[aj<ai]dp[j],dp[0]=1,答案为
a
n
s
[
i
]
=
∑
j
=
0
i
d
p
[
j
]
,
a
n
s
[
0
]
=
1
ans[i]=\sum_{j=0}^{i}dp[j],ans[0]=1
ans[i]=∑j=0idp[j],ans[0]=1。
考虑在序列最末端新加入一个比前面都大的数,
d
p
[
n
+
1
]
=
∑
i
=
0
n
d
p
[
i
]
=
a
n
s
[
n
]
,
a
n
s
[
n
+
1
]
=
2
⋅
a
n
s
[
n
]
dp[n+1]=\sum_{i=0}^{n}dp[i]=ans[n]\;,\;ans[n+1]=2\cdot ans[n]
dp[n+1]=∑i=0ndp[i]=ans[n],ans[n+1]=2⋅ans[n],因此会使得答案乘 2——左移 1。如果在序列最末端加入一个比前面 (除了位置 0) 都小的数,
d
p
[
n
+
1
]
=
d
p
[
0
]
=
1
,
a
n
s
[
n
+
1
]
=
a
n
s
[
n
]
+
1
dp[n+1]=dp[0]=1\;,\;ans[n+1]=ans[n]+1
dp[n+1]=dp[0]=1,ans[n+1]=ans[n]+1,就会使得答案+1,那么就有了一个使序列长度
<
128
<128
<128 的构造方案:
- 从 K 的最高位开始遍历,每到下一位就在序列最后加入一个比前面都大的数。
- 如果当前位为 1,则把序列每个位置整体加 1(答案不变),然后在序列最后加入 1。
于是我们拿到了 28 分的高分。
这个构造方法实际上序列的长度为
log
2
K
+
b
i
t
c
o
u
n
t
(
K
)
\log_2K+bitcount(K)
log2K+bitcount(K),我们会被存在过多 1 的 K 卡到序列长度 98 以上。如果我们能近乎把每一段连续的 1 都只加入 1 个点的话,由于连续的 1 不超过
log
2
K
2
\frac{\log_2K}{2}
2log2K 段,因此可以把序列长度卡到 98 以下。怎么做呢?
我们发现,实际上不可能每一段连续的 1 都只加入一个点,但是稍微把长度卡到 98 以下是可行的。
考虑之前的 DP 计算,我们在最后加入一个数 x 时,实际上是把答案增加了
∑
i
=
0
n
[
a
i
<
x
]
d
p
[
i
]
\sum_{i=0}^{n}[a_i<x]dp[i]
∑i=0n[ai<x]dp[i] 这么多,如果能找到这么一个 x ,使得这个值刚好为
2
?
−
1
2^?-1
2?−1 不就可以优化了?
因此我们维护对于当前每一个值 x,
∑
i
=
0
n
[
a
i
<
x
]
d
p
[
i
]
\sum_{i=0}^{n}[a_i<x]dp[i]
∑i=0n[ai<x]dp[i] 是多少,当我们遍历到一段连续 n 个的 1 时,就先在序列尾部加 n 个比前面都大的数让答案左移 n 位,然后把刚好
∑
i
=
0
n
[
a
i
<
x
]
d
p
[
i
]
=
2
n
−
1
\sum_{i=0}^{n}[a_i<x]dp[i]=2^n-1
∑i=0n[ai<x]dp[i]=2n−1 的 x 加入序列尾部,最后把序列前面 ≥ x 的数都+1。这样就能比较好地优化长度了,实测拍了20000+组 T=1500 的数据,序列长度没有超过 89 的。
CODE
#include<set>
#include<map>
#include<cmath>
#include<ctime>
#include<queue>
#include<vector>
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
#define MAXN 205
#define DB double
#define LL long long
#define ENDL putchar('\n')
#define lowbit(x) (-(x) & (x))
#pragma GCC optimize(2)
LL read() {
LL f = 1,x = 0;char s = getchar();
while(s < '0' || s > '9') {if(s=='-')f = -f;s = getchar();}
while(s >= '0' && s <= '9') {x=x*10+(s-'0');s = getchar();}
return f * x;
}
const int MOD = 998244353;
int n,m,i,j,s,o,k;
int a[MAXN],L,hb,mx;
LL ct[MAXN];
int mp(LL x) {
for(int i = 0;i <= mx;i ++) if(ct[i] == x) return i;
return -1;
}
void addbot(int ad) {
for(int i = 1;i <= L;i ++) if(a[i] > ad) a[i] ++;
mx ++;
for(int i = mx;i > ad+1;i --) swap(ct[i],ct[i-1]);
a[++ L] = ad+1; ct[ad+1] = ct[ad];
for(int i = ad+1;i <= mx;i ++) ct[i] += ct[ad];
return ;
}
int main() {
freopen("make.in","r",stdin);
freopen("make.out","w",stdout);
int T = read();
while(T --) {
LL K = read();
L = 0;
memset(a,0,sizeof(a));
memset(ct,0,sizeof(ct));
hb = 62,mx = 0;
ct[0] = 1ll;
while(!(K & (1ll<<hb))) hb --;
for(int i = hb-1;i >= 0;i --) {
if(K & (1ll<<i)) {
LL tm = 1ll;
while(i > 0 && (K & (1ll<<(i-1)))) {
i --; tm = tm<<1ll|1ll;
}
for(LL tmp = tm;tm > 0ll;tmp = min(tmp,tm)) {
tmp = tm;
int add = 0;
while((add=mp(tmp)) < 0) tmp >>= 1ll;
LL tmc = tmp;
while(tmc > 0) {
a[++ L] = ++ mx; ct[mx] = ct[mx-1]<<1ll;
tm >>= 1ll;
tmc >>= 1ll;
}
addbot(add);
}
}
else {
a[++ L] = ++ mx;
ct[mx] = ct[mx-1]<<1ll;
}
}
printf("%d\n",L);
for(int i = 1;i <= L;i ++) printf("%d ",a[i]);
ENDL;
}
return 0;
}
造序列(构造,DP)的更多相关文章
- At grand 022 GCD序列构造 dp/floyd二进制变换最少费用
A diverse words指的是每一个字母在单词中出现的次数不超过1的单词 题目要求你求出字典序比当前给定单词大的字典序最小单词 1.如果给定的单词长度小于26 就遍历一次在单词尾部加上字典序最小 ...
- 贪心/构造/DP 杂题选做Ⅱ
由于换了台电脑,而我的贪心 & 构造能力依然很拉跨,所以决定再开一个坑( 前传: 贪心/构造/DP 杂题选做 u1s1 我预感还有Ⅲ(欸,这不是我在多项式Ⅱ中说过的原话吗) 24. P5912 ...
- 贪心/构造/DP 杂题选做Ⅲ
颓!颓!颓!(bushi 前传: 贪心/构造/DP 杂题选做 贪心/构造/DP 杂题选做Ⅱ 51. CF758E Broken Tree 讲个笑话,这道题是 11.3 模拟赛的 T2,模拟赛里那道题的 ...
- 【2】【leetcode-105,106】 从前序与中序遍历序列构造二叉树,从中序与后序遍历序列构造二叉树
105. 从前序与中序遍历序列构造二叉树 (没思路,典型记住思路好做) 根据一棵树的前序遍历与中序遍历构造二叉树. 注意:你可以假设树中没有重复的元素. 例如,给出 前序遍历 preorder = [ ...
- [leetcode]从中序与后序/前序遍历序列构造二叉树
从中序与后序遍历序列构造二叉树 根据一棵树的中序遍历与后序遍历构造二叉树. 注意: 你可以假设树中没有重复的元素. 例如,给出 中序遍历 inorder = [9,3,15,20,7] 后序遍历 po ...
- codevs 1962 马棚问题--序列型DP
1962 马棚问题 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 每天,小明和他的马外出,然后他们一边跑一边玩耍.当他们结束 ...
- LeetCode 中级 - 从前序与中序遍历序列构造二叉树(105)
一个前序遍历序列和一个中序遍历序列可以确定一颗唯一的二叉树. 根据前序遍历的特点, 知前序序列(PreSequence)的首个元素(PreSequence[0])为二叉树的根(root), 然后在中 ...
- 括号序列的dp问题模型
括号序列的dp问题模型 Codeforces314E ◦给定一个长度为n的仅包含左括号和问号的字符串,将问号变成左括号或 右括号使得该括号序列合法,求方案总数. ◦例如(())与()()都是合法的括号 ...
- [BZOJ 3992] [SDOI 2015] 序列统计(DP+原根+NTT)
[BZOJ 3992] [SDOI 2015] 序列统计(DP+原根+NTT) 题面 小C有一个集合S,里面的元素都是小于质数M的非负整数.他用程序编写了一个数列生成器,可以生成一个长度为N的数列,数 ...
- LeetCode106. 从中序与后序遍历序列构造二叉树
106. 从中序与后序遍历序列构造二叉树 描述 根据一棵树的中序遍历与后序遍历构造二叉树. 注意: 你可以假设树中没有重复的元素. 示例 例如,给出 中序遍历 inorder = [9,3,15,20 ...
随机推荐
- conda和pip加速参考
conda install和创建虚拟环境下载慢,可以修改/root/.condarc文件: vim /root/.condarc 各系统都可以通过修改用户目录下的 .condarc 文件.Window ...
- 支持向量机SVM(一):基本概念、目标函数的推导
本文旨在介绍支持向量机(SVM)的基本概念并解释SVM中的一个关键问题: 为什么SVM目标函数中的函数间隔取1? 一.分类问题 给定N个分属两类的样本,给出一个决策边界使得边界一侧只含一种样本(如下图 ...
- Kafka 的稳定性
一.事务 1. 事务简介 1.1 事务场景 producer发的多条消息组成⼀个事务这些消息需要对consumer同时可⻅或者同时不可⻅ producer可能会给多个topic,多个partition ...
- vue华视电子身份证阅读器的使用
ie还是谷歌都是可以用的 只需要直接启用华视电子身份证阅读器的服务来的,至于服务已经上传到了网上 华视阅读器服务,下载下来解压,找到对应的华视电子读卡服务.exe文件,路径是CVR-1 ...
- uniapp使用scroll-view与swiper组件实现tab滑动切换页面需要注意的问题
效果图: tab栏可以滑动,切换页面跟随tab栏同步滑动.这里需要注意的是使用swiper组件时,它会有一个默认的高度,你必须动态的获取数据列表的高度覆盖原来的默认高度. 下面是代码 html < ...
- javascript写淡入淡出效果的轮播图
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- 为什么新的5G标准将为技术栈带来更低的 TCO
摘要 新5G标准和边缘计算对低延迟的要求,给那些试图将一堆不同组件组装成一个不会出现故障且仍具有低延迟的高成本效益应用程序公司带来了严峻的挑战.事实上,这个问题非常严重,以至于需要重新考虑架构. ...
- Kotlin学习快速入门(7)——扩展的妙用
原文地址: Kotlin学习快速入门(7)--扩展的妙用 - Stars-One的杂货小窝 之前也模模糊糊地在用这个功能,也是十分方便,可以不用继承,快速给某个类增加新的方法,本篇便是来讲解下Kotl ...
- 写了个 Markdown 命令行小工具,希望能提高园友们发文的效率!
写了个 Markdown 命令行小工具,希望能提高园友们发文的效率! 前言 笔者使用 Typora 来编写 Markdown 格式的博文,图片采用的是本地相对路径存储(太懒了不想折腾图床). 时间久了 ...
- Redis系列3:高可用之主从架构
Redis系列1:深刻理解高性能Redis的本质 Redis系列2:数据持久化提高可用性 1 主从复制介绍 上一篇<Redis系列2:数据持久化提高可用性>中,我们介绍了Redis中的数据 ...