只能维护加入

删除的话,离线可当作倒着加入

一般用set写,下面是bzoj2300,维护凸壳的长度

void add(P x){
  set<P>::iterator l=s.lower_bound(x),r=l,t;
  l--;
  if((*r-*l)*(x-*l)<0)return;
  now-=dis(*r-*l);
  for(;;){
    t=r;r++;
    if(r==s.end())break;
    if((x-*t)*(*r-*t)>0)break;
    now-=dis(*t-*r);
    s.erase(t);
  }
  for(;;){
    if(l==s.begin())break;
    t=l;l--;
    if((x-*t)*(*l-*t)<0)break;
    now-=dis(*t-*l);
    s.erase(t);
  }
  s.insert(x);
  l=r=s.find(x);l--;r++;
  now+=dis(*l-x)+dis(*r-x);
}

  

相关文章:

  • 2021-06-19
  • 2022-02-12
  • 2022-12-23
  • 2021-11-27
  • 2021-06-13
  • 2021-11-02
  • 2022-12-23
  • 2021-07-21
猜你喜欢
  • 2022-03-01
  • 2021-06-27
  • 2021-08-20
  • 2021-10-10
  • 2021-05-23
  • 2022-12-23
  • 2022-02-06
相关资源
相似解决方案