C生涯回忆录题解

招生

https://ac.nowcoder.com/acm/contest/9033/A

这个题数据范围较大,我没看到数据,想直接来一发莫队(好傻的想法)。

很明显,不能直接暴力,我们需要一个O(nlogn)的算法。

这道题通过观察可得,它的任意子集的Mex(x)必定小于等于n+1。

如果不能枚举回忆,那么我们可以去枚举回忆值,正好是1——n+1,再加一个快速幂正好是(nlogn)的算法。

枚举回忆值,很明显分成了比这个数小的一部分,和比这个数大的一部分。

比这个数大的一部分很好求,就是集合2^p(p为大的一部分),难道小的也是这样求吗?

如果真的是这样子求那么前面部分是1,2,3,枚举值是4,前面难道真的等于8,不是,前面只有取1,2,3时才是4。

我们就可以发现前面数字至少有一个,否则枚举值就不是这个子集Mex值。

所以我们要预处理,记录下每个数字出现了多少次。前面部分的值就是每个不同回忆数字的真子集相乘,后面就是比枚举值大的所有数字子集值,因为后面取不取没差,那么这道题目就做完了。

代码如下:

#include <map>
#include <cmath>
#include <queue>
#include <stack>
#include <cstdio>
#include <vector>
#include <cstring>
#include <iostream>
#include <algorithm>
using namespace std;
#define ll long long
#define mem(a,b) memset(a,b,sizeof(a))
#define fo1(a,b) for(int a=0;a<b;++a)
#define fo2(a,b) for(int a=1;a<=b;++a)
#define lowbit(a) (a&(-a))
#define fir(a) a->first
#define sec(a) a->second
const int inf=0x3f3f3f3f;
const int maxn=5e5+5;
const int MOD=20000311;
const double eps=1e-8;
int n,a[maxn];
map <int,int> m;
map <int,bool> vis;
inline ll quickpower(ll a,ll b){
    ll ans=1,base=a;
    while(b){
    if(b&1)
    ans=ans*base%MOD;
    base=base*base%MOD;
    b/=2;
    }
    return ans%MOD;
}
int main()
{
    scanf("%d",&n);
    for(int i=1;i<=n;++i) scanf("%d",&a[i]),m[a[i]]++;
    ll ans=0;
    ll num=0;
    ll cnt=1;
    for(int i=1;i<=n+1;++i){
        num+=(ll)m[i];
        //cout<<num<<endl;
        ans=(ans+((cnt*i)%MOD*(quickpower(2,n-num)))%MOD)%MOD;
        cnt=(cnt*(quickpower(2,m[i])-1))%MOD; //每个数字的集合不能出现空集所以-1
        //cout<<cnt<<"*****"<<endl;
        //cout<<ans<<endl;
    }
    printf("%lld\n",ans);
    return 0;
} 
全部评论
这代码,我先湿了
点赞
送花
回复
分享
发布于 2020-11-22 23:51

相关推荐

点赞 评论 收藏
转发
感觉这一周太梦幻了,就像一个梦,很不真实~~~感觉这个暑期,我的运气占了99成,实力只有百分之一4.15上午&nbsp;腾讯csig&nbsp;腾讯云部门,面完秒进入复试状态4.16下午&nbsp;美团优选供应链部门,4.18上午发二面4.17晚上&nbsp;阿里国际一面,纯拷打,面完我都玉玉了4.18下午&nbsp;阿里国际二面,是我们leader面的我,很轻松~~4.18晚上&nbsp;约了hr面4.19上午&nbsp;hr面,下午两点口头oc4.19晚上&nbsp;意向书说起来我的暑期好像一次都没挂过~~~~~难道我是天生面试圣体?----------------------------------------------------------------------六个月前,我还是0项目0刷题,当时想的是先把论文发出来再去找实习。结果一次组会,老师打破了我的幻想(不让投B会,只让投刊或者A)我拿头投啊!!!然后就开始物色着找实习,顺便做完了mit的6.s081,但是基本上还是没刷过题目-----------------------------------------------------------------------11月&nbsp;&nbsp;一次偶然的机会,面进了某个耳机厂的手环部门,大概是做嵌入式的,用的是CPP。12月&nbsp;莫名其妙拿到了国创的面试机会,0基础四天速成java基础!居然也给我面过了hhhhh,可能是面试没写题吧入职国创后的几个月,一直没活,天天搁那看剧,都快忘了还有暑期实习这回事了~~~~命运的齿轮在2.26开始转动,因为这一天美团开了,我开始慌了,因为那时的我什么都不会。lc,八股,sql全部是0进度。然后就开始了女娲补天,上班刷题,下班继续做之前的开源,顺便学一学八股。3月到现在,lc也刷到快200了,一天最多提交了47次~~~~~~~~~~八股根据别人的面经总结和博客,写了快十万字的笔记~~~~~~~~~~简历上的实习经历和开源,也努力去深挖了,写了几万字的记录~~~~~~所以面试的时候,基本上都能cover了,面试官问到的基础基本都会,不基础的我就把他往我会的地方引。结果好像还不错,基本上每个面试官评价都挺好的emmmmmmmm
投递阿里巴巴等公司10个岗位
点赞 评论 收藏
转发
5 收藏 评论
分享
牛客网
牛客企业服务