Educational Codeforces Round 80 (Rated for Div. 2) E - Messenger Simulator(前缀和,树状数组)

🍓 🍓 🍓

题意:一个1到n的全排列,m次操作,表示将ai移动到数组的第一个位置,求过程中每个数的最小位置和最大位置。

1,最小值为 1 or 初始位置

2,最大值出现在某次移动这个数之前 or 全部移动完成之后

3,因为数字不重复,所以将该位置有无元素转换成01序列,维护一个前缀和即可(记得空出来移动的位置)

int n, m;
int c[MAXN*2];
void update(int x,int v){ while (x <= n+m) {c[x]+=v; x += (x & (-x)); }}
int que(int x){int sum = 0; while (x) { sum += c[x]; x -= (x & (-x)); }return sum;}
signed main()
{
    cin >> n >> m;
    vector<int> ans1(n+1), ans2(n+1), a(m), pos(n+1);
    rpp(i,n)
    {
        ans1[i] = ans2[i] = i;  pos[i]= i+m;
        update(i+m,1);
    }
    int l=m;
    rep(i, m)
    {
        cin >> a[i];ans1[a[i]] = 1;
        ans2[a[i]]=max(ans2[a[i]],que(pos[a[i]]));
        update(pos[a[i]],-1);
        pos[a[i]]=l--;
        update(pos[a[i]],1);
    }
    rpp(i,n) ans2[i] = max(ans2[i],que(pos[i]));
    rpp(i,n) cout<<ans1[i]<<" "<<ans2[i]<<endl;
    return 0;
}

发布了210 篇原创文章 · 获赞 1 · 访问量 5237
展开阅读全文

没有更多推荐了,返回首页

©️2019 CSDN 皮肤主题: 游动-白 设计师: 上身试试

分享到微信朋友圈

×

扫一扫,手机浏览