[决策单调 分治] LOJ#535. 「LibreOJ Round #6」花火

48人阅读 评论(0) 收藏 举报
分类:

如果 i<jai>aj 那么 i 作为左端点比 j 优,右端点同理

那么搞出两个上升序列,发现右端点递增的时候左端点也是单调上升的,也就是gjghfdvector说的具有决策单调

分治就好了

#include <cstdio>
#include <iostream>
#include <algorithm>

using namespace std;

const int N=300010;

int n,cnt,a[N],Q1[N],rt[N],tot[N*20],ls[N*20],rs[N*20],top1,Q2[N],top2;

void Add(int &g,int l,int r,int x){
  int k=g; g=++cnt; ls[g]=ls[k]; rs[g]=rs[k]; tot[g]=tot[k]+1;
  if(l==r) return ;
  int mid=l+r>>1;
  if(x<=mid) Add(ls[g],l,mid,x);
  else Add(rs[g],mid+1,r,x);
}

int Query(int g,int l,int r,int L,int R){
  if((l==L && r==R) || !tot[g]) return tot[g];
  int mid=L+R>>1;
  if(r<=mid) return Query(ls[g],l,r,L,mid);
  else if(l>mid) return Query(rs[g],l,r,mid+1,R);
  else return Query(ls[g],l,mid,L,mid)+Query(rs[g],mid+1,r,mid+1,R);
}

int t[N];

inline int Qu(int x){
  int ret=0;
  for(;x<=n;x+=x&-x) ret+=t[x];
  return ret;
}

inline void Ad(int x){ for(;x;x-=x&-x) t[x]++; }

int l,r,Max,res[N],pos[N];

inline int calc(int l,int r){
  if(a[l]<a[r] || l>=r) return -1;
  return Query(rt[r],a[r],a[l]-1,1,n)-1-Query(rt[l],a[r],a[l]-1,1,n);
}

void solve(int l,int r,int L,int R){
  if(L>R) return ;
  if(l==r){
    for(int i=L;i<=R;i++){
      int cur=calc(Q1[l],Q2[i]);
      if(cur>res[i]) res[i]=cur,pos[i]=l;
    }
    return ;
  }
  int mid=L+R>>1; res[mid]=0;
  for(int i=l;i<=r;i++){
    int cur=calc(Q1[i],Q2[mid]);
    if(cur>res[mid]) res[mid]=cur,pos[mid]=i;
  }
  solve(l,pos[mid],L,mid-1);
  solve(pos[mid],r,mid+1,R);
}

int main(){
  scanf("%d",&n);
  for(int i=1;i<=n;i++){
    scanf("%d",&a[i]); rt[i]=rt[i-1];
    Add(rt[i],1,n,a[i]);
  }
  for(int i=1;i<=n;i++){
    if(a[i]>a[Q1[top1]]) Q1[++top1]=i;
    while(top2 && a[i]<a[Q2[top2]]) top2--;
    Q2[++top2]=i;
  }
  solve(1,top1,1,top2); l=r=0;
  for(int i=1;i<=top2;i++)
    if(res[i]>Max) Max=res[i],l=Q1[pos[i]],r=Q2[i];
  swap(a[l],a[r]);
  long long ans=l!=r;
  for(int i=1;i<=n;i++) ans+=Qu(a[i]),Ad(a[i]);
  printf("%lld\n",ans);
  return 0;
}
查看评论

[博弈论][二分图匹配][网络流] LOJ #536. 「LibreOJ Round #6」花札

SolutionSolutionSolution 这是一个Undirected Vertex Geography。 可以 O(n3)O(n3)\mathcal{O}(n^3) 对每个点得到答案。 ...
  • Vectorxj
  • Vectorxj
  • 2018年02月27日 10:10
  • 65

[线段树分治][DP] LOJ #534. 「LibreOJ Round #6」花团

SolutionSolutionSolution 操作相当于是动态的做一个背包DP。 离线的话,线段树分治一下。 因为结尾是已知的,可以一边分治,得到一个修改操作,就插到线段树。 只要保证分治...
  • Vectorxj
  • Vectorxj
  • 2018年02月26日 20:59
  • 44

[链分治] LOJ #511. 「LibreOJ NOI Round #1」验题

直接按照字典序类似逐位确定 先从后往前诸位确定确定答案和当前的LCP 然后在从前往后逐位确定 然后就转化为一个 某些不能选 某些必须选 某些随意 的独立集计数 链分治#include #inc...
  • u014609452
  • u014609452
  • 2017年07月23日 13:18
  • 285

「LibreOJ β Round #4」求和 莫比乌斯函数

https://loj.ac/problem/528不含平方因子的数才会有 -1 和 1才会对结果造成影响, 所有排除掉所有含有平方因子的数就好开始的时候平方是1 就是没有平方因子的情况,减去所有平...
  • Hallelujah520
  • Hallelujah520
  • 2017年09月03日 18:08
  • 231

LibreOJ #505.「LibreOJ β Round」ZQC 的游戏 网络流

题意分析比赛的时候唯一一道想出来的题。。。直接网络流就好了。没啥好说的。代码#include #include #include #include #include #include using na...
  • qq_33229466
  • qq_33229466
  • 2017年06月17日 08:07
  • 312

loj#526. 「LibreOJ β Round #4」子集

给N个点,给出建边的条件,求图中的最大团,直接跑最大团模板会超时,建个对偶图,跑二分图匹配,最大团子集中点的个数就是n-匹配数 #include #include using namespace s...
  • constbh
  • constbh
  • 2017年09月06日 10:46
  • 106

「LibreOJ β Round #2 D题」计算几何瞎暴力 Trie树整体xor的trick

题目链接 背景:博主前天晚上水了一波LOJ的BetaRound2,花了2h写了某三个水水的签到题后便处于无所事事的颓废状态,             想rush一下D题,但idea一直是挂的,最终...
  • Marco_L_T
  • Marco_L_T
  • 2017年07月04日 23:41
  • 295

「LibreOJ β Round #2」贪心只能过样例 [bitset]【STL】

题目链接:https://loj.ac/problem/515 ——————————————————————————————————515. 「LibreOJ β Round #2」贪心只能过样例内...
  • qq_33184171
  • qq_33184171
  • 2017年07月03日 14:51
  • 465

[线段树] LOJ #535. 「LibreOJ Round #6」花火

SolutionSolutionSolution 现将所有数转化为二维平面上的点(i,hi)(i,hi)(i,h_i)。 几个性质: 交换两个数(i,j),(i≤j,hi&gt;hj)...
  • Vectorxj
  • Vectorxj
  • 2018年02月26日 19:30
  • 35

#507. 「LibreOJ NOI Round #1」接竹竿 dp

简单的dp,直接硬上就好了。#include #include #include #define fo(i,a,b) for(int i=a;i=b;i--) using namespace std;...
  • qq_35866453
  • qq_35866453
  • 2017年07月08日 08:00
  • 187
    个人资料
    持之以恒
    等级:
    访问量: 10万+
    积分: 5255
    排名: 6489
    文章分类
    最新评论