题意

给出n个点,每个点有a,b两个属性,让你从左下角到右上角划一条线,线的左边每个点的贡献是\(a_i\),线的右边每个点的贡献是\(b_i\),使得两部分的总和最大。

分析

找一条折线将点分割开,使总和最大。

把y离散化,然后点按x排序,设\(dp[i]\)为经过第\(i\)个点(该点当作B集合中的点)的折线的权值,之前的点中在这个点上面的点dp值要加上\(b[i]\),之前的点中在这个点下面的点的dp值要加上\(a[i]\)

  • \(dp[i]=max(dp[i],dp[k]+b[i]),y[k]<=y[i]\)
  • \(dp[k]=dp[k]+b[i],y[k]>y[i]\)
  • \(dp[k]=dp[k]+a[i],y[k]<y[i]\)

用线段树来维护dp值就行了

Code

#include<bits/stdc++.h>
#define fi first
#define se second
#define pb push_back
#define lson l,mid,p<<1
#define rson mid+1,r,p<<1|1
#define ll long long
using namespace std;
const int inf=1e9;
const int mod=1e9+7;
const int maxn=1e5+10;
int n;
struct ppo{
int x,y,a,b;
bool operator <(const ppo &r) const{
if(x==r.x) return y>r.y;
return x<r.x;
}
}a[maxn];
int b[maxn],m;
ll tr[maxn<<2],tag[maxn<<2];
void pp(int p){
tr[p]=max(tr[p<<1],tr[p<<1|1]);
}
void pd(int p,ll k){
tr[p]+=k;tag[p]+=k;
}
void bd(int l,int r,int p){
tag[p]=0;
if(l==r){
tr[p]=0;return;
}int mid=l+r>>1;
bd(lson);bd(rson);pp(p);
}
void up(int x,int l,int r,int p,ll k){
if(l==r){
tr[p]=max(tr[p],k);return;
}int mid=l+r>>1;
pd(p<<1,tag[p]);pd(p<<1|1,tag[p]);tag[p]=0;
if(x<=mid) up(x,lson,k);
else up(x,rson,k);pp(p);
}
void add(int dl,int dr,int l,int r,int p,ll k){
if(l>r) return;
if(l>=dl&&r<=dr){
tr[p]+=k;tag[p]+=k;return;
}int mid=l+r>>1;
pd(p<<1,tag[p]);pd(p<<1|1,tag[p]);tag[p]=0;
if(dl<=mid) add(dl,dr,lson,k);
if(dr>mid) add(dl,dr,rson,k);pp(p);
}
ll qy(int dl,int dr,int l,int r,int p){
if(l>r) return 0;
if(l>=dl&&r<=dr){
return tr[p];
}int mid=l+r>>1;ll ret=0;
pd(p<<1,tag[p]);pd(p<<1|1,tag[p]);tag[p]=0;
if(dl<=mid) ret=max(ret,qy(dl,dr,lson));
if(dr>mid) ret=max(ret,qy(dl,dr,rson));
return ret;
}
int main(){
//ios::sync_with_stdio(false);
//freopen("in","r",stdin);
while(~scanf("%d",&n)){
for(int i=1;i<=n;i++){
scanf("%d%d%d%d",&a[i].x,&a[i].y,&a[i].a,&a[i].b);
b[i]=a[i].y;
}
sort(b+1,b+n+1);
m=unique(b+1,b+n+1)-b-1;
for(int i=1;i<=n;i++){
a[i].y=lower_bound(b+1,b+m+1,a[i].y)-b+1;
}
sort(a+1,a+n+1);
m++;
bd(1,m,1);
for(int i=1;i<=n;i++){
ll ret=qy(1,a[i].y,1,m,1);
up(a[i].y,1,m,1,ret+a[i].b);
add(1,a[i].y-1,1,m,1,a[i].a);
add(a[i].y+1,m,1,m,1,a[i].b);
}
printf("%lld\n",tr[1]);
}
return 0;
}

2019牛客暑期多校训练营(第一场)I dp+线段树的更多相关文章

  1. 2019牛客暑期多校训练营(第二场) H-Second Large Rectangle(单调栈)

    题意:给出由01组成的矩阵,求求全是1的次大子矩阵. 思路: 单调栈 全是1的最大子矩阵的变形,不能直接把所有的面积存起来然后排序取第二大的,因为次大子矩阵可能在最大子矩阵里面,比如: 1 0 0 1 ...

  2. 2019牛客暑期多校训练营(第九场) D Knapsack Cryptosystem

    题目 题意: 给你n(最大36)个数,让你从这n个数里面找出来一些数,使这些数的和等于s(题目输入),用到的数输出1,没有用到的数输出0 例如:3  4 2 3 4 输出:0 0 1 题解: 认真想一 ...

  3. 2019牛客暑期多校训练营(第五场)G - subsequeue 1 (一题我真的不会的题)

    layout: post title: 2019牛客暑期多校训练营(第五场)G - subsequeue 1 (一题我真的不会的题) author: "luowentaoaa" c ...

  4. 2019牛客暑期多校训练营(第一场)A Equivalent Prefixes(单调栈/二分+分治)

    链接:https://ac.nowcoder.com/acm/contest/881/A来源:牛客网 Two arrays u and v each with m distinct elements ...

  5. 2019牛客暑期多校训练营(第一场)A题【单调栈】(补题)

    链接:https://ac.nowcoder.com/acm/contest/881/A来源:牛客网 题目描述 Two arrays u and v each with m distinct elem ...

  6. 2019牛客暑期多校训练营(第一场) B Integration (数学)

    链接:https://ac.nowcoder.com/acm/contest/881/B 来源:牛客网 Integration 时间限制:C/C++ 2秒,其他语言4秒 空间限制:C/C++ 5242 ...

  7. 2019牛客暑期多校训练营(第一场) A Equivalent Prefixes ( st 表 + 二分+分治)

    链接:https://ac.nowcoder.com/acm/contest/881/A 来源:牛客网 Equivalent Prefixes 时间限制:C/C++ 2秒,其他语言4秒 空间限制:C/ ...

  8. 2019牛客暑期多校训练营(第二场)F.Partition problem

    链接:https://ac.nowcoder.com/acm/contest/882/F来源:牛客网 Given 2N people, you need to assign each of them ...

  9. 2019牛客暑期多校训练营(第九场)A:Power of Fibonacci(斐波拉契幂次和)

    题意:求Σfi^m%p. zoj上p是1e9+7,牛客是1e9:  对于这两个,分别有不同的做法. 前者利用公式,公式里面有sqrt(5),我们只需要二次剩余求即可.     后者mod=1e9,5才 ...

  10. 2019牛客暑期多校训练营(第八场)E.Explorer

    链接:https://ac.nowcoder.com/acm/contest/888/E来源:牛客网 Gromah and LZR have entered the fifth level. Unli ...

随机推荐

  1. 关于spring中AOP的几件小事

    0.AOP简介 AOP(Aspect-Oriented Programming,面向切面编程):是一种新的方法论,是穿透OOP的补充. AOP的主要编程对象是切面(aspect),而切面模块化横切关注 ...

  2. ReadWriteLock读写之间互斥吗

    开发中遇到并发的问题一般会用到锁,Synchronized存在明显的一个性能问题就是读与读之间互斥:ReadWriteLock是JDK5中提供的读写分离锁.读写分离锁可以有效地帮助减少锁竞争,以提升系 ...

  3. Vue访问权限

    设置权限 <script> export default { created(){ if(this.$store.state.userStore.role !== 'manager'){ ...

  4. Js-声明变量

    JS声明变量 js声明变量的方式有3种:let,const,var 1.const如果定义简单数据类型,变成常量,变量值不可以更改. const name="lili"; name ...

  5. Excel中把图片合并进图表的方法介绍

    方法一: 使用“图案”对话框 双击某个数据系列,选择“图案”标签,单击“填充效果”按钮,在“填充效果”对话框中选择“图片”标签,单击“选择图片”按钮,选择一个要使用的图形文件即可. 方法二: 使用剪贴 ...

  6. Java高并发程序设计学习笔记(十):并发调试和JDK8新特性

    转自:https://blog.csdn.net/dataiyangu/article/details/87631574 多线程调试的方法使用Eclipse进行多线程调试线程dump及分析分析死锁案例 ...

  7. Delphi最新的路线图

    没想到,官方又发布了一个路线图,同上一个相比,多了10.3.3版本,而其中,最主要的iOS 13支持,即下半年发布的新的苹果系统,再一个就是android 64的delphi支持!年底前发布,够官忙伙 ...

  8. fastadmin 页面添加编辑日期时间

    添加 <div class="form-group"> <label class="control-label col-xs-12 col-sm-2&q ...

  9. zabbix 邮件报警(五)

    一.sendEmail配置zabbix邮件报警 1.下载sendEmail: wget http://caspian.dotconf.net/menu/Software/SendEmail/sendE ...

  10. Tomcat 启动卡在 Root WebApplicationContext: initialization completed in

    tomcat 启动一直卡在 Root WebApplicationContext: initialization completed in 重启了很多次,更换jdk版本,tomcat版本都不行. to ...