社区讨论
RE求调
P14962 [LBA-OI R2 A] 一次买够参与者 1已保存回复 0
讨论操作
快速查看讨论及其快照的属性,并进行相关操作。
- 当前回复
- 0 条
- 当前快照
- 1 份
- 快照标识符
- @mk9h53di
- 此快照首次捕获于
- 2026/01/11 16:30 上个月
- 此快照最后确认于
- 2026/01/11 16:39 上个月
CPP
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
struct G
{
int v,w;
} g[3005];
int main()
{
ios::sync_with_stdio(false);
cin.tie(0);
int n,m;
cin>>n>>m;
int M=-1;
for(int i=1;i<=n;++i)
{
cin>>g[i].v>>g[i].w;
M=max(M,g[i].w);
}
multiset<int> b;
set<pair<int,int>> u;
ll t=0;
for(int i=1;i<=n;++i)
{
if(g[i].w==M)
{
b.insert(g[i].w);
t+=g[i].v;
}
else
u.insert({-g[i].w,g[i].v});
}
int c=n;
while(m--)
{
int o,x,y;
cin>>o>>x>>y;
if(o==1)
{
c++;
g[c].v=x;
g[c].w=y;
u.insert({-y,x});
}
else
{
int O=g[x].w;
g[x].w=y;
if(b.count(O))
{
b.erase(b.find(O));
b.insert(y);
}
else
{
u.erase(u.find({-O,g[x].v}));
u.insert({-y,g[x].v});
}
}
if(!b.empty())
{
int L=*b.begin();
while(!u.empty())
{
auto i=u.begin();
int w=-i->first;
if(w>=L)
{
t+=i->second;
b.insert(w);
u.erase(i);
}
else
break;
}
}
cout<<t<<'\n';
}
return 0;
}
回复
共 0 条回复,欢迎继续交流。
正在加载回复...