正题

题目链接:https://www.ybtoj.com.cn/problem/643


题目大意

\(n\)个机器人,第\(i\)个攻击力为\(A_i\),防御为\(D_i\)。

然后你每次可以对一个机器人造成\(Atk\)点伤害,之后所有机器人对你进行一次攻击。

开局可以删除两个机器人,求最少受到多少伤害。

\(n\in[3,3\times 10^5],A_i,T_i\in[1,10^4]\)


解题思路

设每个机器人需要攻击的次数\(T_i\)

先不考虑删除的话是一个很经典的贪心,按照\(\frac{T_i}{A_i}\)从小到大排序就好了。证明的话

设目前是排序好的序列,是否交换相邻的两个\(i,j(j>i)\)需要满足

\[T_iA_j\geq T_jA_i
\]

化简一下就可以发现一定不合法

然后考虑删除哪两个,设\(St_i=\sum_{j=1}^iT_i,Sa_i=\sum_{j=1}^nA_i\),那么删除一个\(x\)会减少贡献

\[b_x=(Sa_n-Sa_x)T_x+St_xA_x-A_x
\]

(分别计算自己减去的和自己对后面的数产生的贡献)。

但是如果删除了两个数\(x,y(x<y)\)就会多减去\(T_xA_y\)的贡献。

所以我们要求$$\max{ b_x+b_y-T_xA_y } (x<y)$$

这个因为值域比较小直接上李超树就好了,当然也可以\(CDQ\)分治或者\(Splay\)搞斜率优化

时间复杂度\(O(n\log n)\)


code

#include<cstdio>
#include<cstring>
#include<algorithm>
#define ll long long
using namespace std;
const ll N=3e5+10;
struct node{
ll b,k;
};
ll n,atk,sum,ans,maxs,lim;
ll p[N],a[N],t[N],st[N],sa[N],b[N],w[N];
bool cmp(ll x,ll y)
{return t[x]*a[y]<t[y]*a[x];}
ll ct(ll x,ll id)
{return t[p[id]]*x+b[id];}
void Change(ll x,ll l,ll r,ll id){
if(ct(l,id)>=ct(l,w[x])&&ct(r,id)>=ct(l,w[x])){w[x]=id;return;}
if(ct(l,id)<=ct(l,w[x])&&ct(r,id)<=ct(r,w[x]))return;
if(l==r)return;ll mid=(l+r)>>1;
if(t[p[id]]<t[p[w[x]]]){
if(ct(mid,id)>=ct(mid,w[x]))
Change(x*2+1,mid+1,r,w[x]),w[x]=id;
Change(x*2,l,mid,id);
}
else{
if(ct(mid,id)>=ct(mid,w[x]))
Change(x*2,l,mid,w[x]),w[x]=id;
Change(x*2+1,mid+1,r,id);
}
return;
}
ll Ask(ll x,ll l,ll r,ll pos){
if(l==r)return ct(pos,w[x]);
ll mid=(l+r)>>1,ans;
if(pos<=mid)ans=Ask(x*2,l,mid,pos);
else ans=Ask(x*2+1,mid+1,r,pos);
return max(ans,ct(pos,w[x]));
}
signed main()
{
freopen("fittest.in","r",stdin);
freopen("fittest.out","w",stdout);
scanf("%lld%lld",&n,&atk);
for(ll i=1;i<=n;i++){
scanf("%lld%lld",&a[i],&t[i]);
t[i]=(t[i]+atk-1)/atk;p[i]=i;
sum+=a[i];lim=max(max(a[i],t[i]),lim);
}
sort(p+1,p+1+n,cmp);b[0]=-1e18;
for(ll i=1;i<=n;i++){
ll x=p[i];
st[i]=st[i-1]+t[x];
sa[i]=sa[i-1]+a[x];
b[i]=(sum-sa[i])*t[x]+st[i]*a[x]-a[x];
ans+=st[i]*a[x]-a[x];
}
for(ll i=1;i<=n;i++){
int x=p[i];
ll tmp=b[i]+Ask(1,1,lim,a[x]);
maxs=max(maxs,tmp);t[x]=-t[x];
Change(1,1,lim,i);
}
printf("%lld\n",ans-maxs);
return 0;
}

YbtOJ#643-机器决斗【贪心,李超树】的更多相关文章

  1. BZOJ4391 High Card Low Card [Usaco2015 dec](贪心+线段树/set库

    正解:贪心+线段树/set库 解题报告: 算辣直接甩链接qwq 恩这题就贪心?从前往后从后往前各推一次然后找一遍哪个地方最大就欧克了,正确性很容易证明 (这里有个,很妙的想法,就是,从后往前推从前往后 ...

  2. BZOJ1568: [JSOI2008]Blue Mary开公司【李超树】

    Description Input 第一行 :一个整数N ,表示方案和询问的总数. 接下来N行,每行开头一个单词"Query"或"Project". 若单词为Q ...

  3. #6034. 「雅礼集训 2017 Day2」线段游戏 李超树

    #6034. 「雅礼集训 2017 Day2」线段游戏 内存限制:256 MiB时间限制:1000 ms标准输入输出 题目类型:传统评测方式:Special Judge 上传者: 匿名 提交提交记录统 ...

  4. Good Inflation SPOJ - GOODG 李超树

    题目传送门 题意:刚开始有一个气球体积为空,现在有n个充气点,从1->n遍历这n充气点,每个充气点有vi,di,vi为走到这个充气点之后可以为气球充气vi的体积,di为选择了在这个点充气的时候, ...

  5. 【题解】P1712 [NOI2016]区间(贪心+线段树)

    [题解]P1712 [NOI2016]区间(贪心+线段树) 一个observe是,对于一个合法的方案,将其线段长度按照从大到小排序后,他极差的来源是第一个和最后一个.或者说,读入的线段按照长度分类后, ...

  6. [SDOI2016]游戏(树剖+李超树)

    趁着我把李超树忘个一干二净的时候来复习一下吧,毕竟马上NOI了. 题解:看着那个dis就很不爽,直接把它转换成深度问题,然后一条直线x->y,假设其lca为z,可以拆分成x->z和z-&g ...

  7. P4254 [JSOI2008]Blue Mary开公司 (李超树)

    题意:插入一些一次函数线段 每次询问在x = x0处这些线段的最大值 题解:李超树模版题 维护优势线段 注意这题的输入是x=1时的b #include <iostream> #includ ...

  8. Codeforces 675E Trains and Statistic(DP + 贪心 + 线段树)

    题目大概说有n(<=10W)个车站,每个车站i卖到车站i+1...a[i]的票,p[i][j]表示从车站i到车站j所需买的最少车票数,求所有的p[i][j](i<j)的和. 好难,不会写. ...

  9. poj 2010 Moo University - Financial Aid (贪心+线段树)

    转载请注明出处,谢谢http://blog.csdn.net/ACM_cxlove?viewmode=contents    by---cxlove 骗一下访问量.... 题意大概是:从c个中选出n个 ...

随机推荐

  1. 基于WindowsService的WebSocket编程Demo

    一.什么是WebSocket WebSocket协议是基于TCP的一种新的网络协议.它实现了浏览器与服务器全双工(full-duplex)通信--允许服务器主动发送信息给客户端.说了半天也就是说有了它 ...

  2. Qt foreach关键字用法(无师自通)

    Qt 提供一个关键字 foreach (实际是 <QtGlobal> 里定义的一个宏)用于方便地访问容器里所有数据项. foreach 关键字用于遍历容路中所有的项,使用 foreach ...

  3. 嵌入式Linux的启动过程

    1.了解 Linux 最初是由瑞典赫尔辛基大学的学生 Linus Torvalds在1991 年开发出来的,之后在 GNU的支持下,Linux 获得了巨大的发展.虽然 Linux 在桌面 PC 机上的 ...

  4. jQuery中的事件(八):on()、off()、bind()、unbind()、one()、hover()、hide()、show()、offset()等

    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <hea ...

  5. 一招解决下载或下拉GitHub项目速度太慢的问题

    相信很多朋友都有过这样的体验,就是从Github上下载或clone别人的项目时特别慢,甚至还会出现链接意外终止的情况,那么今天就来给大家分享一个提速的方法,步骤也非常简单,亲测有效! 首先进入你的目标 ...

  6. Go: 复合数据类型struct

    结构体 结构体是将零个或多个任意类型的命名变量组合在一起的聚合数据类型.每个变量都叫做结构体的成员. type Employee struct { ID int Name string age int ...

  7. redis rpoplpush列表转移元素

    文档出处:redisdoc.com/list/rpoplpush.html模式: 安全的队列 Redis的列表经常被用作队列(queue),用于在不同程序之间有序地交换消息(message).一个客户 ...

  8. 删除mysql数据库后django重建数据库

    问题:由于表的结构设计的不太合理,后来要添加列,但是在django中使用makemigrations一直失败. 解决:索性就把mysql中对于django的数据库删了(其实也不用删除),在django ...

  9. Linux系统的vsftpd服务配置

    概述: FTP ( 文件传输协议 ) 是 INTERNET 上仍常用的最老的网络协议之一 , 它为系统提供了通过网络与远程服务器进行传输的简单方法FTP 服务器包的名称为 VSFTPD , 它代表 V ...

  10. SpringMVC-源码-图解