joig2022_e 题解
设计 \(f_i\) 表示以第 \(i\) 个数结尾的选择的最大值。
有 \(f_i = f_j + a_i\)(\(type_i \not = type_j\))。
发现可以选择的种类其实构成两段连续区间。
所以维护使得 \(type_x = i\) 的所有 \(x\) 的 \(f_x\) 最大值。
这个用线段树可以很简洁的维护。
于是就 \(O(n \log n)\) 地做完了。
#include<bits/stdc++.h>
#define int long long
using namespace std;
const int inf = 1e18+7;
const int maxn=150010;
int dp[maxn];
int type[maxn],a[maxn],n,m,ans;
int tree[maxn*4];
void pushup(int x)
{
tree[x]=max(tree[x*2],tree[x*2+1]);
}
void add(int now,int val,int l,int r,int x)
{
if(l==r)
{
tree[x]+=val;
return ;
}
int mid=(l+r)/2;
if(now<=mid)
add(now,val,l,mid,x*2);
else
add(now,val,mid+1,r,x*2+1);
pushup(x);
return ;
}
int question(int L,int R,int l,int r,int x)
{
if(R>n||L<1||R<L)
return 0;
if(L<=l&&R>=r)
{
return tree[x];
}
int mid=(l+r)/2,res=-inf;
if(L<=mid)
res=max(res,question(L,R,l,mid,x*2));
if(R>mid)
res=max(res,question(L,R,mid+1,r,x*2+1));
return res;
}
signed main()
{
ios::sync_with_stdio(0);
cin.tie(0);
cout.tie(0);
for(int i=0;i<maxn*4;i++) tree[i]=-inf;
cin>>n>>m;
for(int i=1;i<=n;i++)
cin>>type[i]>>a[i];
dp[1]=a[1];
ans=max(ans,dp[1]);
add(type[1],inf,1,m,1);
add(type[1],a[1],1,m,1);
for(int i=2;i<=n;i++)
{
dp[i]=max(question(1,type[i]-1,1,m,1),max(question(type[i]+1,m,1,m,1),0*1ll))+a[i];
if(dp[i]>question(type[i],type[i],1,m,1))
{
int u=question(type[i],type[i],1,m,1);
add(type[i],-u,1,m,1);
add(type[i],dp[i],1,m,1);
}
ans=max(ans,dp[i]);
}
cout<<ans;
}
joig2022_e 题解的更多相关文章
- 2016 华南师大ACM校赛 SCNUCPC 非官方题解
我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...
- noip2016十连测题解
以下代码为了阅读方便,省去以下头文件: #include <iostream> #include <stdio.h> #include <math.h> #incl ...
- BZOJ-2561-最小生成树 题解(最小割)
2561: 最小生成树(题解) Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1628 Solved: 786 传送门:http://www.lyd ...
- Codeforces Round #353 (Div. 2) ABCDE 题解 python
Problems # Name A Infinite Sequence standard input/output 1 s, 256 MB x3509 B Restoring P ...
- 哈尔滨理工大学ACM全国邀请赛(网络同步赛)题解
题目链接 提交连接:http://acm-software.hrbust.edu.cn/problemset.php?page=5 1470-1482 只做出来四道比较水的题目,还需要加强中等题的训练 ...
- 2016ACM青岛区域赛题解
A.Relic Discovery_hdu5982 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Jav ...
- poj1399 hoj1037 Direct Visibility 题解 (宽搜)
http://poj.org/problem?id=1399 http://acm.hit.edu.cn/hoj/problem/view?id=1037 题意: 在一个最多200*200的minec ...
- 网络流n题 题解
学会了网络流,就经常闲的没事儿刷网络流--于是乎来一发题解. 1. COGS2093 花园的守护之神 题意:给定一个带权无向图,问至少删除多少条边才能使得s-t最短路的长度变长. 用Dijkstra或 ...
- CF100965C题解..
求方程 \[ \begin{array}\\ \sum_{i=1}^n x_i & \equiv & a_1 \pmod{p} \\ \sum_{i=1}^n x_i^2 & ...
- JSOI2016R3 瞎BB题解
题意请看absi大爷的blog http://absi2011.is-programmer.com/posts/200920.html http://absi2011.is-programmer.co ...
随机推荐
- LogAgen的工作流程
LogAgen的工作流程: 一.读日志 --tailf 第三方库 新建tail_test/main.go package main import ( "fmt" "git ...
- JOISC2019 题解
\(\text{By DaiRuiChen007}\) Contest Link A. Examination Problem Link 题目大意 有 \(n\) 个二元组 \((a,b)\) 和 \ ...
- 数据库—SQL语言学习
文章目录 SQL 数据类型 重要的关键字 定义数据库 数据库的文件 table创建与删除 表的定义 表的alter 表的删除 视图 定义视图 删除视图 更新视图 插入视图 视图总结 索引 SQL单表查 ...
- 鸿蒙HarmonyOS实战-Stage模型(服务卡片介绍和运行机制)
一.服务卡片介绍 1.服务卡片的概念 在HarmonyOS中,服务卡片是一种提供即时信息和快速操作的小组件,类似于Android中的通知栏.服务卡片可以显示各种类型的信息,包括通知.天气.日历事件.音 ...
- SASS 插值语句 #{ }的使用
在之前我们已经使用用 / 来进行计算,但如下情况不一样 例如 p{ font: 16px/30px Arial, Helvetica, sans-serif; } 如果需要使用变量,同时又要确保 / ...
- linux wget命令的重要用法:下载文件并保存,后台下载
Linux wget命令是一个下载文件的工具,它用在命令行下. #从网络下载一个文件并保存在当前目录 [root@node5 ~]# wget http://cn.wordpress.org/word ...
- 基于webapi的websocket聊天室(番外二)
我比较好奇的是webapi服务器怎么处理http请求和websocket请求.有了上一篇番外的研究,这里就可以试着自己写个非常简易的webapi服务器来接收这两种请求. 效果 http请求 消息打印 ...
- Git 出现 Permission denied 时,重新生成ssh密钥
1,右键本地仓库,点击 [ Git Bash Here] 出现如下对话框: 输入 ssh-keygen 然后一直回车,注意: 保存的SSH目录 在 C:\Users\xiaocj\.ssh ...
- 地图坐标转换 WGS84、BD09与GCJ02的相互转换
高德地图 WGS84转GCJ02 export function wgs84ToGcj02(lng, lat) { if (out_of_china(lng, lat)) { return [lng, ...
- C# 关于图片转ICO的代码整理(无损,不需要第三方类库)
概述(Overview) 感觉网上文章整理的不全,我这边做个专栏,专门做这个事情吧,节省大家搜索.筛选.整理的时间精力.有用可以点个赞.引用本文章请注明出处,谢谢. (I feel that the ...