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;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值