ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

Nowcoder9983I.序列的美观度(线段树+DP)

2021-02-06 13:02:23  阅读:164  来源: 互联网

标签:mathit int 线段 Si maxn Nowcoder9983I ans 序列 DP


链接:https://ac.nowcoder.com/acm/contest/9983/I
来源:牛客网

设一个长度为m\mathit mm的序列S\mathit SS的美观度等于有多少个整数i\mathit ii满足1≤i≤m−11\leq i \leq m-11≤i≤m−1且Si=Si+1S_{i}=S_{i+1}Si​=Si+1​,其中SiS_{i}Si​代表序列S\mathit SS的第i\mathit ii个元素。
给出一个长度为n\mathit nn的序列a\mathit aa,问在他的所有子序列美观度最大是多少。
某个序列的子序列是从最初序列通过去除某些元素(也可以不去除,即序列本身也是子序列)但不破坏余下元素的相对位置(在前或在后)而形成的新序列。

#include<bits/stdc++.h>
using namespace std;
const int maxn=1e6+100;
const int M=1e6;
int n,a[maxn],f[maxn],vis[maxn];
struct node {
    int l,r,sum;
}segTree[maxn<<2];
void build (int i,int l,int r) {
    segTree[i].l=l;
    segTree[i].r=r;
    if (l==r) {
        segTree[i].sum=0;
        return;
    }
    int mid=(l+r)>>1;
    build(i<<1,l,mid);
    build(i<<1|1,mid+1,r);
    segTree[i].sum=max(segTree[i<<1].sum,segTree[i<<1|1].sum);
}
void up (int i,int p,int v) {
    if (segTree[i].l==p&&segTree[i].r==p) {
        segTree[i].sum=v;
        return;
    }
    int mid=(segTree[i].l+segTree[i].r)>>1;
    if (p<=mid) up(i<<1,p,v);
    if (p>mid) up(i<<1|1,p,v);
    segTree[i].sum=max(segTree[i<<1].sum,segTree[i<<1|1].sum);
}
int query (int i,int l,int r) {
    if (l>r) return 0;
    if (segTree[i].l>=l&&segTree[i].r<=r) return segTree[i].sum;
    int mid=(segTree[i].l+segTree[i].r)>>1;
    int ans=0;
    if (l<=mid) ans=max(ans,query(i<<1,l,r));
    if (r>mid) ans=max(ans,query(i<<1|1,l,r));
    return ans;
}
int main () {
    scanf("%d",&n);
    build(1,1,M);
    for (int i=1;i<=n;i++) scanf("%d",a+i);
    //f(a(i))表示以a(i)结尾的子序列的最大美观度
    for (int i=1;i<=n;i++) {
        f[a[i]]=max(query(1,1,a[i]-1),query(1,a[i]+1,M));
        if (vis[a[i]]) 
            f[a[i]]=max(query(1,a[i],a[i])+1,f[a[i]]);
        else
            vis[a[i]]=1;
        up(1,a[i],f[a[i]]);
    } 
    printf("%d\n",query(1,1,M));
}

 

标签:mathit,int,线段,Si,maxn,Nowcoder9983I,ans,序列,DP
来源: https://www.cnblogs.com/zhanglichen/p/14381196.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有