洛谷P3097 - [USACO13DEC]最优挤奶Optimal Milking

2024-03-19 17:58

本文主要是介绍洛谷P3097 - [USACO13DEC]最优挤奶Optimal Milking,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Portal

Description

给出一个\(n(n\leq4\times10^4)\)个数的数列\(\{a_n\}(a_i\geq1)\)。一个数列的最大贡献定义为其中若干个不相邻的数的和的最大值。进行\(m(m\leq5\times10^4)\)次操作,每次修改数列中的一个数并询问此时的最大贡献。

Solution

线段树。
对于线段树上每个节点\([L,R]\),维护四个值\(f_{00},f_{01},f_{10},f_{11}\),分别表示\(a_L,a_R\)都不选,不选\(a_L\)\(a_R\),选\(a_L\)不选\(a_R\)\(a_L,a_R\)都选的最大贡献。那么\(ans=max\{f[rt]\}\)
接下来只需要考虑如何合并。其实很简单,只要保证中间的两个不全是\(1\)就好:
\[ f_{00}=max\{f_{00}[Ls]+f_{00}[Rs],f_{01}[Ls]+f_{00}[Rs],f_{00}[Ls]+f_{10}[Rs]\} \\ f_{01}=max\{f_{00}[Ls]+f_{01}[Rs],f_{01}[Ls]+f_{01}[Rs],f_{00}[Ls]+f_{11}[Rs]\} \\ f_{10}=max\{f_{10}[Ls]+f_{00}[Rs],f_{11}[Ls]+f_{00}[Rs],f_{10}[Ls]+f_{10}[Rs]\} \\ f_{11}=max\{f_{10}[Ls]+f_{01}[Rs],f_{11}[Ls]+f_{01}[Rs],f_{10}[Ls]+f_{11}[Rs]\}\]

时间复杂度\(O(mlogn)\)

Code

//[USACO13DEC]最优挤奶Optimal Milking
#include <cstdio>
typedef long long lint;
inline char gc()
{static char now[1<<16],*s,*t;if(s==t) {t=(s=now)+fread(now,1,1<<16,stdin); if(s==t) return EOF;}return *s++;
}
inline int read()
{int x=0; char ch=gc();while(ch<'0'||'9'<ch) ch=gc();while('0'<=ch&&ch<='9') x=x*10+ch-'0',ch=gc();return x;
}
inline int max(int x,int y) {return x>y?x:y;}
const int N=16e4+10;
int n,m;
#define Ls (p<<1)
#define Rs (p<<1|1)
int rt; lint f00[N],f01[N],f10[N],f11[N];
inline void update(int p)
{f00[p]=max(f00[Ls]+f00[Rs],max(f01[Ls]+f00[Rs],f00[Ls]+f10[Rs]));f01[p]=max(f00[Ls]+f01[Rs],max(f01[Ls]+f01[Rs],f00[Ls]+f11[Rs]));f10[p]=max(f10[Ls]+f00[Rs],max(f11[Ls]+f00[Rs],f10[Ls]+f10[Rs]));f11[p]=max(f10[Ls]+f01[Rs],max(f11[Ls]+f01[Rs],f10[Ls]+f11[Rs]));
}
void ins(int p,int L0,int R0,int x,int v)
{if(L0==x&&x==R0) {f00[p]=f01[p]=f10[p]=0,f11[p]=v; return;}int mid=L0+R0>>1;if(x<=mid) ins(Ls,L0,mid,x,v);else ins(Rs,mid+1,R0,x,v);update(p);
}
int main()
{n=read(),m=read();rt=1;for(int i=1;i<=n;i++) ins(rt,1,n,i,read());lint ans=0;for(int i=1;i<=m;i++){int x=read(),v=read();ins(rt,1,n,x,v);ans+=max(max(f00[rt],f01[rt]),max(f10[rt],f11[rt]));}printf("%lld\n",ans);return 0;
}

P.S.

标题好长呀...

转载于:https://www.cnblogs.com/VisJiao/p/LgP3097.html

这篇关于洛谷P3097 - [USACO13DEC]最优挤奶Optimal Milking的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/826812

相关文章

usaco 1.2 Milking Cows(类hash表)

第一种思路被卡了时间 到第二种思路的时候就觉得第一种思路太坑爹了 代码又长又臭还超时!! 第一种思路:我不知道为什么最后一组数据会被卡 超时超了0.2s左右 大概想法是 快排加一个遍历 先将开始时间按升序排好 然后开始遍历比较 1 若 下一个开始beg[i] 小于 tem_end 则说明本组数据与上组数据是在连续的一个区间 取max( ed[i],tem_end ) 2 反之 这个

一些数学经验总结——关于将原一元二次函数增加一些限制条件后最优结果的对比(主要针对公平关切相关的建模)

1.没有分段的情况 原函数为一元二次凹函数(开口向下),如下: 因为要使得其存在正解,必须满足,那么。 上述函数的最优结果为:,。 对应的mathematica代码如下: Clear["Global`*"]f0[x_, a_, b_, c_, d_] := (a*x - b)*(d - c*x);(*(b c+a d)/(2 a c)*)Maximize[{f0[x, a, b,

4-4.Andorid Camera 之简化编码模板(获取摄像头 ID、选择最优预览尺寸)

一、Camera 简化思路 在 Camera 的开发中,其实我们通常只关注打开相机、图像预览和关闭相机,其他的步骤我们不应该花费太多的精力 为此,应该提供一个工具类,它有处理相机的一些基本工具方法,包括获取摄像头 ID、选择最优预览尺寸以及打印相机参数信息 二、Camera 工具类 CameraIdResult.java public class CameraIdResult {

高精度计算(代码加解析,洛谷p1601,p1303)除法待更新

目录 高精度加法 高精度减法 高精度乘法 高精度加法 我们知道在c++语言中任何数据类型都有一定的表示范围。当两个被加数很大时,正常加法不能得到精确解。在小学,我们做加法都采用竖式方法。那么我们也只需要按照加法进位的方式就能得到最终解。 8 5 6+ 2 5 5-------1 1 1 1 加法进位: c[i] = a[i] + b[i];if(c[i] >=

洛谷 凸多边形划分

T282062 凸多边形的划分 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) 先整一个半成品,高精度过两天复习一下补上 #include <iostream>#include <algorithm>#include <set>#include <cstring>#include <string>#include <vector>#include <map>

能量项链,洛谷

解释:  环形dp问题还是考虑将环拉直,可以参考我上一篇文章:环形石子合并 [2 3 5 10 2] 3 5 10 将环拉直,[]内是一个有效的区间,可以模拟吸收珠子的过程,         如[2 3 5] <=>(2,3)(3,5)    2是头,3是中间,5是尾 len >= 3:因为最后[2 10 2]是最小的可以合并的有效区间 len <= n + 1因为[2 3

华为OD机试 - 最优结果的a数组数量 - 贪心思维(Java 2024 E卷 100分)

华为OD机试 2024E卷题库疯狂收录中,刷题点这里 专栏导读 本专栏收录于《华为OD机试(JAVA)真题(E卷+D卷+A卷+B卷+C卷)》。 刷的越多,抽中的概率越大,私信哪吒,备注华为OD,加入华为OD刷题交流群,每一题都有详细的答题思路、详细的代码注释、3个测试用例、为什么这道题采用XX算法、XX算法的适用场景,发现新题目,随时更新,全天CSDN在线答疑。 一、题目描述

清华MEM作业-利用管理运筹学的分析工具slover求解最优解的实现 及 通过使用文件或者套节字来识别进程的fuser命令

一、清华MEM作业-利用管理运筹学的分析工具slover求解最优解的实现         最近又接触了一些线性求解的问题,以前主要都是在高中数学里接触到,都是使用笔算,最后通过一些函数式得出最小或者最大值,最近的研究生学业上接触到了一个Excel solver分析工具,对这种线性求最优解的问题感觉使用起来真是得心应手。在使用这个工具前,EXCEL里需要先装上solver工具,装起来很也简单,网上

洛谷P5490扫描线

0是最小的数字,将一个线段看成一个区间,对于一个矩形,从下扫到上,入边为1,而出边为-1,意思是将这个区间上的所有点加1(区间修改).把线段表示为Line[i],其中记录了l,r,h,tag,左右端点,高度,入边还是出边(1或-1) 那么每次区间修改后不为0的区间它的值可能是1,2,3或者是其它数字,这不好统计,可以将它转化一下,0是不是表示没有被覆盖过的地方,我们只要统计0的个数然后用总长减去

【POJ】2728 Desert King 最优比率生成树——01分数规划【经典】

最近在刷巨巨们放出来的专题,然后没做几题就卡住了,果然还是太弱了T U T... 这次做到了一题01分数规划求解的生成树问题。 题目大意是这样的:给你一个无向完全图,每条边i都有两个权值,长度a[ i ],花费b[ i ],需要选出其中的一些边构造一颗生成树,生成树需要满足条件:∑ b [ i ] / ∑ a [ i ]最小。 这样我还是先来介绍一下01分数规划吧~ 给定一个上述的问