ABC 203 F - Weed (DP)
ABC203F - Weed
题意转述

S
t
e
v
e
\rm Steve
Steve 和
A
l
e
x
\rm Alex
Alex 正在下界(
N
e
t
h
e
r
l
e
n
d
\rm Netherlend
Netherlend)玩音符盒(
N
o
t
e
b
l
o
c
k
\rm Note~block
Note block)。
S
t
e
v
e
\rm Steve
Steve 和
A
l
e
x
\rm Alex
Alex 按下了按钮,听着各色音符被发光的红石线激活,感到无比欢乐。但是他们发现有的音符盒发不出声音,原因是被垂泪藤占据了上方的空气方块。于是
S
t
e
v
e
\rm Steve
Steve 和
A
l
e
x
\rm Alex
Alex 打算清除这些垂泪藤。他们是这样清除的:
- (为了有效地清除垂泪藤,他们打算到垂泪藤上方,挖掉它们上面的方块,除根)
- S
t
e
v
e
\rm Steve
Steve 先记下了其中至多
K
K
K 条垂泪藤,上去挖掉了它们上面的方块,清除它们。
- A
l
e
x
\rm Alex
Alex 重复进行这样的操作,直到所有垂泪藤被清除完: 找到长度最大的一条未除掉的垂泪藤的长度
H
H
H ,告诉
S
t
e
v
e
\rm Steve
Steve 所有未除掉的长度大于
H
2
\frac{H}{2}
2H 的垂泪藤的位置,然后让他除掉它们。
S
t
e
v
e
\rm Steve
Steve 想让
A
l
e
x
\rm Alex
Alex 进行的操作次数最少,在这个前提下,自己一开始记忆的垂泪藤数(
≤
K
\leq K
≤K)尽可能少。但是一共有
N
(
≤
2
⋅
1
0
5
)
N(\leq2\cdot10^5)
N(≤2⋅105) 条长度
h
i
≤
1
0
9
h_i\leq10^9
hi≤109 的垂泪藤(有个强大的模组消除了高度限制),于是
S
t
e
v
e
\rm Steve
Steve 想先向你询问,满足他的要求的情况下,
A
l
e
x
\rm Alex
Alex 进行的操作数和自己一开始记忆的垂泪藤数分别是多少。
题解
由于每次操作过后,最长的垂泪藤长度都至少会减半,因此,总操作数一定不会超过
log
H
m
a
x
+
1
=
31
\log H_{max}+1=31
logHmax+1=31,那么我们就可以用一个简单的
D
y
n
a
m
i
c
P
r
o
g
r
a
m
m
i
n
g
\rm Dynamic~Programming
Dynamic Programming 来解决这道题:
先把所有的垂泪藤按长度从小到大排序,令
d
p
[
i
]
[
j
]
dp[i][j]
dp[i][j] 表示以第
j
j
j 条垂泪藤为最长开始,进行了
i
i
i 次操作后,清除的最大可能条数(
d
p
[
0
]
[
0
]
=
0
dp[0][0]=0
dp[0][0]=0)。有如下转移:
d
p
[
i
]
[
j
]
=
max
2
h
k
≤
h
j
d
p
[
i
−
1
]
[
k
]
+
∑
2
h
k
>
h
j
,
k
≤
j
1
dp[i][j]=\max_{2h_k\leq h_j} dp[i-1][k]+\sum_{2h_k>h_j,k\leq j}1
dp[i][j]=2hk≤hjmaxdp[i−1][k]+2hk>hj,k≤j∑1
这个可以通过预处理以及前缀和优化等方式达到
O
(
1
)
O(1)
O(1) 转移,也当然可以用滚动少掉一维。
如果找到了最小的
i
i
i ,使得
d
p
[
i
]
m
a
x
≥
N
−
K
dp[i]_{max}\geq N-K
dp[i]max≥N−K,那么就可以输出
i
i
i 和
N
−
d
p
[
i
]
m
a
x
N-dp[i]_{max}
N−dp[i]max 了。
开头可以加个
k
=
n
k=n
k=n 的特判。
CODE
#include<cstdio>
#include<vector>
#include<cmath>
#include<ctime>
#include<queue>
#include<map>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
#define MAXN 200005
#define DB double
#define LL long long
#define ENDL putchar('\n')
#define lowbit(x) ((-x) & (x))
#define INF 0x3f3f3f3f
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;
}
int n,m,i,j,s,o,k;
int a[MAXN];
int dp[2][MAXN];
int main() {
n = read();k = read();
for(int i = 1;i <= n;i ++) {
a[i] = read();
}
if(k == n) {printf("0 %d\n",n);return 0;}
sort(a + 1,a + 1 + n);
int ans = 0;
for(int i = 1;i <= 32;i ++) {
int ad = 0,mx = 0;
for(int j = 1;j <= n;j ++) {
while(ad < n && a[ad+1] <= a[j]/2) mx = max(mx,dp[i&1^1][++ ad]);
dp[i&1][j] = mx + (j-ad);
ans = max(dp[i&1][j],ans);
}
if(ans >= n-k) {printf("%d %d\n",i,n-ans);return 0;}
}
return 0;
}
ABC 203 F - Weed (DP)的更多相关文章
- Codeforces Round #471 (Div. 2) F. Heaps(dp)
题意 给定一棵以 \(1\) 号点为根的树.若满足以下条件,则认为节点 \(p\) 处有一个 \(k\) 叉高度为 \(m\) 的堆: 若 \(m = 1\) ,则 \(p\) 本身就是一个 \(k\ ...
- 牛客国庆集训派对Day6 && CCPC-WannaFly-Camp #1 F. kingdom(DP)
题目链接:https://www.nowcoder.com/acm/contest/206/F 题意:一棵 n 个点的树,根为 1,重儿子到父亲的费用为 0,其余为 1,问所有点到 1 的最大总费用是 ...
- LightOJ 1033 Generating Palindromes(dp)
LightOJ 1033 Generating Palindromes(dp) 题目链接:http://acm.hust.edu.cn/vjudge/contest/view.action?cid= ...
- UVA11125 - Arrange Some Marbles(dp)
UVA11125 - Arrange Some Marbles(dp) option=com_onlinejudge&Itemid=8&category=24&page=sho ...
- 【POJ 3071】 Football(DP)
[POJ 3071] Football(DP) Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 4350 Accepted ...
- 初探动态规划(DP)
学习qzz的命名,来写一篇关于动态规划(dp)的入门博客. 动态规划应该算是一个入门oier的坑,动态规划的抽象即神奇之处,让很多萌新 萌比. 写这篇博客的目标,就是想要用一些容易理解的方式,讲解入门 ...
- Tour(dp)
Tour(dp) 给定平面上n(n<=1000)个点的坐标(按照x递增的顺序),各点x坐标不同,且均为正整数.请设计一条路线,从最左边的点出发,走到最右边的点后再返回,要求除了最左点和最右点之外 ...
- Leetcode之动态规划(DP)专题-647. 回文子串(Palindromic Substrings)
Leetcode之动态规划(DP)专题-647. 回文子串(Palindromic Substrings) 给定一个字符串,你的任务是计算这个字符串中有多少个回文子串. 具有不同开始位置或结束位置的子 ...
- Leetcode之动态规划(DP)专题-392. 判断子序列(Is Subsequence)
Leetcode之动态规划(DP)专题-392. 判断子序列(Is Subsequence) 给定字符串 s 和 t ,判断 s 是否为 t 的子序列. 你可以认为 s 和 t 中仅包含英文小写字母. ...
随机推荐
- 『忘了再学』Shell基础 — 29、AWK内置变量
目录 1.AWK内置变量 2.练习说明 (1)$n变量练习 (2)FS变量练习 (3)NF变量和NR变量练习 3.总结: 1.AWK内置变量 AWK内置变量如下表: awk内置变量 作用 $0 代表目 ...
- rpc的正确打开方式|读懂Go原生net/rpc包
前言 最近在阅读字节跳动开源RPC框架Kitex的源码,分析了如何借助命令行,由一个IDL文件,生成client和server的脚手架代码,也分析了Kitex的日志组件klog.当然Kitex还有许多 ...
- 分享一个基于 netty 的 java 开源项目
1.简介 中微子代理(neutrino-proxy)是一个基于 netty 的.开源的 java 内网穿透项目.遵循 MIT 许可,因此您可以对它进行复制.修改.传播并用于任何个人或商业行为. 2.项 ...
- JS:eval
定义和用法: eval() 函数计算 JavaScript 字符串,并把它作为脚本代码来执行.eval()函数并不会创建一个新的作用域,并且它的作用域就是它所在的作用域. 如果参数是一个表达式,eva ...
- BUUCTF-LSB
LSB 看到这个题目应该是LSB隐写,StegSolve打开,在红绿蓝0号上发现图片信息 然后在Analyse选择data extract Save bin保存图片即可 得到的是个二维码,解码即可.
- JavaScript 语言入门
目录 JavaScript 介绍 JavaScript 和 和 html 代码的结合方式 第一种方式 第二种方式 4.变量 关系(比较)运算 逻辑运算 数组(重点) 函数(重点) 函数的二种定义方式 ...
- 微服务探索之路04篇k8s增加子节点,metrics资源监控,ingress-nginx域名配置及https配置
1 k8s增加子节点 1.1 子节点服务器安装docker,使用脚本自动安装 curl -fsSL https://get.docker.com | bash -s docker --mirror A ...
- 用Python制作爆款视频,没想到吧?
前几天小编在抖音上刷到一个慢慢变老的视频,播放量居然有 30W+,当时就在想这视频 Python 可不可以做?经过一番搜索,小编找到了腾讯云的人脸年龄变化 API,上面介绍说只要用户上传一张人脸图片, ...
- .NetCore|.Net6 gRPC服务开发及本地调试
前言 最近在项目中实装应用了gRPC技术,本着能把技术描述出来给别人能看的懂的思想及作为自己学习笔记的心态编写了此文.因为在实际项目中是webApi接口和gRPC接口使用在同一项目服务中,所以本文的例 ...
- STC8H开发(十三): I2C驱动DS3231高精度实时时钟芯片
目录 STC8H开发(一): 在Keil5中配置和使用FwLib_STC8封装库(图文详解) STC8H开发(二): 在Linux VSCode中配置和使用FwLib_STC8封装库(图文详解) ST ...