社区讨论

我的代码CCF测会满吗

P14359[CSP-J 2025] 异或和参与者 5已保存回复 4

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
4 条
当前快照
1 份
快照标识符
@mhiydms7
此快照首次捕获于
2025/11/03 17:44
4 个月前
此快照最后确认于
2025/11/03 17:44
4 个月前
查看原帖
我用map实现的会超时吗
求大佬给一下复杂度
CPP
#include<bits/stdc++.h>
using namespace std;
map<int,pair<bool,int>>mp;
int f[500200],n,m,a[500200],l[500200],now;
int main()
{
  ios::sync_with_stdio(0);
  cin>>n>>m;
  for(int i=1;i<=n;i++) cin>>a[i];
  mp[0].first=1;mp[0].second=0;
  for(int i=1;i<=n;i++)
  {
    now^=a[i];
    if(a[i]==m) l[i]=i;
    else if(mp[now^m].first) l[i]=mp[now^m].second+1;
    mp[now].first=1;mp[now].second=i;
  }
  for(int i=1;i<=n;i++)
  {
    f[i]=f[i-1];
    if(l[i])f[i]=max(f[i],f[l[i]-1]+1);
  }
  cout<<f[n];
  return 0;
}

回复

4 条回复,欢迎继续交流。

正在加载回复...