LOJ 2840「JOISC 2018 Day 4」糖
有趣的脑子题(可惜我没有脑子
好像也可以称为模拟费用流(?
我们考虑用链表维护这个东西 再把贡献扔到堆里贪心就好了
大概就是类似于有反悔机制的贪心?我们相当于把选中的一个打上一个-v的tag然后如果选了它旁边的就把它取消掉 也是一个打tag的思想
说起来不是很好描述 看代码可能会更好理解(?
//Love and Freedom.
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<cmath>
#include<queue>
#define ll long long
#define inf 20021225
#define pa pair<ll,int>
#define mp make_pair
#define fs first
#define se second
#define N 200001
using namespace std;
int read()
{
int s=,f=; char ch=getchar();
while(ch<''||ch>''){if(ch=='-') f=-; ch=getchar();}
while(ch>=''&&ch<='') s=s*+ch-'',ch=getchar();
return s*f;
}
int pre[N],nxt[N]; ll val[N];
int a[N],n; bool vis[N];
priority_queue<pa> hp;
void upd(int x)
{
vis[x]=;
nxt[pre[x]]=nxt[x];
pre[nxt[x]]=pre[x];
}
int main()
{
n=read(); ll ans=; val[]=-1ll*inf*inf; val[n+]=-1ll*inf*inf;
for(int i=;i<=n;i++)
val[i]=a[i]=read(),pre[i]=i-,nxt[i]=i+,hp.push(mp(val[i],i));
for(int i=;i+i-<=n;i++)
{
while(vis[hp.top().se]) hp.pop();
pa tmp=hp.top(); hp.pop();
ll v=tmp.fs; int pos=tmp.se;
ans+=v; printf("%lld\n",ans);
int l=pre[pos],r=nxt[pos];
val[pos]=val[l]+val[r]-val[pos];
if(l && r<=n) hp.push(mp(val[pos],pos));
upd(l); upd(r);
}
return ;
}
LOJ 2840「JOISC 2018 Day 4」糖的更多相关文章
- [LOJ #2833]「JOISC 2018 Day 1」帐篷
		
题目大意:有一个$n\times m$的网格图,若一个人的同一行或同一列有人,他就必须面向那个人,若都无人,就可以任意一个方向.若一个人无法确定方向,则方案不合法,问不同的方案数.$n,m\leqsl ...
 - loj#2838 「JOISC 2018 Day 3」比太郎的聚会
		
分析 预处理每个点的前根号小的距离 对于每次询问删除点小于根号则已经处理好 否则直接暴力dp即可 代码 #include<bits/stdc++.h> using namespace st ...
 - LOJ #2831. 「JOISC 2018 Day 1」道路建设 线段树+Link-cut-tree
		
用 LCT 维护颜色相同连通块,然后在线段树上查一下逆序对个数就可以了. code: #include <cstdio> #include <algorithm> #inclu ...
 - Loj #2731 「JOISC 2016 Day 1」棋盘游戏
		
Loj 2731 「JOISC 2016 Day 1」棋盘游戏 JOI 君有一个棋盘,棋盘上有 \(N\) 行 \(3\) 列 的格子.JOI 君有若干棋子,并想用它们来玩一个游戏.初始状态棋盘上至少 ...
 - LOJ 2737 「JOISC 2016 Day 3」电报 ——思路+基环树DP
		
题目:https://loj.ac/problem/2737 相连的关系形成若干环 / 内向基环树 .如果不是只有一个环的话,就得断开一些边使得图变成若干链.边的边权是以它为出边的点的点权. 基环树的 ...
 - LOJ 2736 「JOISC 2016 Day 3」回转寿司 ——堆+分块思路
		
题目:https://loj.ac/problem/2736 如果每个询问都是 l = 1 , r = n ,那么每次输出序列的 n 个数与本次操作的数的最大值即可.可以用堆维护. 不同区间的询问,可 ...
 - loj 2392「JOISC 2017 Day 1」烟花棒
		
loj 答案显然满足二分性,先二分一个速度\(v\) 然后显然所有没有点火的都会往中间点火的人方向走,并且如果两个人相遇不会马上点火,要等到火快熄灭的时候才点火,所以这两个人之后应该在一起行动.另外有 ...
 - @loj - 6353@「CodePlus 2018 4 月赛」组合数问题 2
		
目录 @description@ @solution@ @accepted code@ @details@ @description@ 请你找到 k 个不同的组合数,使得对于其中任何一个组合数 \(C ...
 - 「JOISC 2018 Day 3」比太郎的聚会
		
题解: 很套路的题目 我们按照询问中的不算的个数是否大于$block$分类 如果大于,就$O(n)dp$一下 如果小于,就预处理出到每个点前$block$小的点 $block取\sqrt{n}$的话复 ...
 
随机推荐
- Django的media配置与富文本编辑器使用的实例
			
效果预览 文章列表 添加文章 编辑文章|文章详情|删除文章 项目的基本文件 项目的Model from django.db import models # 导入富文本编辑器相关的模块 from cke ...
 - python-笔记(四)函数
			
一.函数是什么? 函数一次来源于数学,但是编程中的[函数]的概念,与数学中的函数还是有很大的不同的,编程中的函数在英文中也有很多不同的叫法. 在Basic中叫做subroutine(子过程或子程序), ...
 - 搭建spring项目,无法创建RequestMappingHandlerMapping异常
			
异常详情: Error creating bean with name 'org.springframework.web.servlet.mvc.method.annotation.RequestMa ...
 - python 每周作业
			
day2:python的简介与认识day2:# 1.写一个登录程序# username# passwd# 让用户输入账号和密码,输入用户和密码输入正确的话# 提示你 xxx,欢迎登录,今天的日期是xx ...
 - 只有一个form 的程序, onactivate 只触发一次。
			
https://blog.csdn.net/saint13/article/details/454615 Form的onActivate事件 2005年08月15日 01:08:00 阅读数:3406 ...
 - LeetCode 94. Binary Tree Inorder Traversal  动态演示
			
非递归的中序遍历,要用到一个stack class Solution { public: vector<int> inorderTraversal(TreeNode* root) { ve ...
 - airtestUI简单操作
			
touch 判断坐标位置 如touch((500, 600), duration=1) swipe 滑动位置 wait 等待画面出现 exists 判断画面中是否存在某个图片 test 调用输入法,输 ...
 - [Python3 填坑] 011 元组中有多个最值,索引出来的是哪一个
			
目录 1. print( 坑的信息 ) 2. 开始填坑 (1) max() (2) min() (3) 结论 1. print( 坑的信息 ) 挖坑时间:2019/01/11 明细 坑的编码 内容 P ...
 - css-sprite 雪碧图的使用,合并多张小图,背景图片当按钮的设置
			
背景图片基础: 使用background-image来设置背景图片 语法: background-image:url(相对与css的路径) 如果背景图片大于元素,默认会显示图片的左上角 如果背景图片和 ...
 - 剑指Offer编程题(Java实现)——数组中的重复数字
			
题目描述 在一个长度为n的数组里的所有数字都在0到n-1的范围内. 数组中某些数字是重复的,但不知道有几个数字是重复的.也不知道每个数字重复几次.请找出数组中任意一个重复的数字. 例如,如果输入长度为 ...