首页 > 其他分享 >[SCOI2014]方伯伯的玉米田题解

[SCOI2014]方伯伯的玉米田题解

时间:2022-12-03 17:56:38浏览次数:40  
标签:le int 题解 玉米 玉米田 ch 数组 SCOI2014 dp

[SCOI2014]方伯伯的玉米田

题目描述

方伯伯在自己的农田边散步,他突然发现田里的一排玉米非常的不美。这排玉米一共有 \(N\) 株,它们的高度参差不齐。方伯伯认为单调不下降序列很美,所以他决定先把一些玉米拔高,再把破坏美感的玉米拔除掉,使得剩下的玉米的高度构成一个单调不下降序列。方伯伯可以选择一个区间,把这个区间的玉米全部拔高 \(1\) 单位高度,他可以进行最多 \(K\) 次这样的操作。拔玉米则可以随意选择一个集合的玉米拔掉。问能最多剩多少株玉米,来构成一排美丽的玉米。

输入格式

第一行包含两个整数 \(n, K\),分别表示这排玉米的数目以及最多可进行多少次操作。第二行包含 \(n\) 个整数,第 \(i\) 个数表示这排玉米,从左到右第 \(i\) 株玉米的高度 \(a_i\)。

输出格式

输出一个整数,最多剩下的玉米数。

样例 #1

样例输入 #1

3 1
2 1 3

样例输出 #1

3

提示

\(100\%\) 的数据满足:$2 \le N \lt 10^4 $,\(2 \le K \le 500\),\(1 \leq a_i \leq 5000\)。

思路

定义 \(dp[i][j]\) 表示以 \(i\) 结尾,可以拔高 \(j\) 次的最长不下降子序列。

状态转移方程:

\[dp[i][j]=\max_{p,q}^{1 \le p < i,0\le q\le j,a[i]+j\ge a[p]+q} dp[p][q]+1 \]

直接暴力转移显然不行,时间复杂度 \(O(n^2k^2)\) ,一分没有。

观察发现每次拔高后最长不下降子序列的长度不会减少,所以可以用二维树状数组维护 \(dp\) 数组,但需要改一下状态。

\(dp[a][b]\) 表示 \([1,i-1]\) 中最多拔高 \(b\) 次,末尾不超过 \(a\) 的最长不下降子序列的长度(类似于 \(n\log n\) 求LIS的 \(low\) 数组)。

把 \(dp\) 数组丢到树状数组里就好了。

时间复杂度 \(O(nk\log n \log k)\) 。

代码

#include<bits/stdc++.h>
using namespace std;
int read(){
	int x=0,f=1;char ch=getchar();
	while(ch<'0'||ch>'9'){if(ch=='-')f=-f;ch=getchar();}
	while(ch>='0'&&ch<='9'){x=(x<<1)+(x<<3)+(ch^48);ch=getchar();}
	return x*f;
}
void write(int x){
	if(x<0){putchar('-');x=-x;}
	if(x>9)write(x/10);
	putchar(x%10+'0');
}
int a[10005],f[10005][1005],n,k,maxx,_ans;
//树状数组模板
int lowbit(int x){
	return x&(-x);
}
void change(int x,int y,int val){
	for(int i=x;i<=maxx+k;i+=lowbit(i))
		for(int j=y;j<=k+1;j+=lowbit(j))
			f[i][j]=max(f[i][j],val);
}
int ask(int x,int y){
	int ans=0;
	for(int i=x;i;i-=lowbit(i))
		for(int j=y;j;j-=lowbit(j))
			ans=max(ans,f[i][j]);
	return ans;
}
//---------------
int main(){
	n=read(),k=read();
	for(int i=1;i<=n;i++)a[i]=read(),maxx=max(maxx,a[i]);
	for(int i=1;i<=n;i++){
		for(int j=k;j>=0;j--){
			int t=ask(a[i]+j,j+1)+1;//找到dp[a[i]+j][j+1]
			_ans=max(_ans,t);//更新答案
			change(a[i]+j,j+1,t);//放入树状数组
		}
	}
	printf("%d\n",_ans);
	return 0;
}

标签:le,int,题解,玉米,玉米田,ch,数组,SCOI2014,dp
From: https://www.cnblogs.com/maniubi/p/16948453.html

相关文章

  • Ynoi2011题解
    d1t1初始化题意一个长度为\(n\)的序列,\(q\)次操作。询问\([l,r]\)的区间和。将所有\(\bmodx=y\)的下标位置加\(z\)。\(n,q\leq2\times10^5\)。题解......
  • CF1710 题解
    比赛链接:https://codeforces.com/contest/1711BD比以往的要难,E要更简单A水题//bySkyRainWind#include<cstdio>#include<vector>#include<cassert>#include<c......
  • 问题解决系列:从源码讲解为什么是 'JZ0SL_ Unsupported SQL type 1111'
    一、问题场景正在做代码改造,使用​​mybatis​​​+​​sybase​​进行数据库操作,运行过程中,提示以下报错:java.io.IOException:JZ0SL:UnsupportedSQLtype1111.本篇博客......
  • npm 报错:npm ERR! Maximum call stack size exceeded 超过最大栈问题解决方案
    先尝试将npm升级到最新版1234$npminstallnpm-g#检查版本$npm-v6.14.5运行以下命令删除当前路径下的node_modules目录1234$rmnode_mo......
  • 2022年Kubernetes CKA 认证真题解析完整版
    第一题RBAC授权问题权重:4%设置配置环境:[student@node-1]$kubectlconfiguse-contextk8sContext为部署管道创建一个新的ClusterRole并将其绑定到范围为特定的name......
  • 互联网最全cka真题解析-2022
    1、CKA真题解析kubectl自动补全及帮助信息1、配置kubectl自动补全aptinstallbash-completionsource<(kubectlcompletionbash)2、kubectlexplans帮助信息3、kubec......
  • 关于mac电脑突然搜不到家里wifi但手机却能连上的问题解决
    今天用mac电脑时,突然遇到一个奇怪的问题,家里wifi用的好好的,突然就连不上了,在看电脑能搜索到的wifi,居然家里的wifi都没有搜索到,但自己的手机却是正常的,然后我再看看我另外......
  • [ABC251Ex] Fill Triangle 题解
    [ABC251Ex]FillTriangleSolution目录[ABC251Ex]FillTriangleSolution更好的阅读体验戳此进入题面SolutionCodeUPD更好的阅读体验戳此进入题面存在序列$a_n$,将......
  • ABC246Ex 01? Queries 题解
    ABC246Ex01?QueriesSolution目录ABC246Ex01?QueriesSolution更好的阅读体验戳此进入浅谈DDP与广义矩阵乘法(戳此进入)引入例题#1广义矩阵乘法DDP例题#0例题#0.5......
  • USACO 2018 Jan 题解
    USACO2018JanSolution目录USACO2018JanSolution更好的阅读体验戳此进入题面Luogu链接LG-P4188[USACO18JAN]LifeguardsS题面SolutionCodeLG-P4182[USACO18JAN]L......