UVA - 12298 Super Poker II NTT

UVA - 12298 Super Poker II NTT

链接

Vjudge

思路

暴力开个桶,然后统计,不过会T,用ntt或者fft,ntt用个大模数就行了,百度搜索"NTT大模数"。

错误

我也不知道,改着改着自己就A了

思路

#include <bits/stdc++.h>
#define ll long long
using namespace std;
const ll N=1e7+7,mod=39582418599937LL;
char s;
bool vis[N];
ll A[4][N],len[4],r[N];
ll read() {
    ll x=0,f=1;s=getchar();
    for(;s>'9'||s<'0';s=getchar()) if(s=='-') f=-1;
    for(;s>='0'&&s<='9';s=getchar()) x=x*10+s-'0';
    return x*f;
}
ll mul(ll u,ll v){return ((u*v-(ll)((long double)u/mod*v+1e-8)*mod)%mod+mod)%mod;}
ll q_pow(ll a,ll b) {
    ll ans=1;
    while(b) {
        if(b&1) ans=mul(ans,a);
        a=mul(a,a);
        b>>=1;
    }
    return ans;
}
void ntt(ll *a,ll limit,ll type) {
    for(ll i=0;i<=limit;++i)
        if(i<r[i]) swap(a[i],a[r[i]]);
    for(ll mid=1;mid<limit;mid<<=1) {
        ll Wn=q_pow(5,(mod-1)/(mid<<1));
        for(ll i=0;i<limit;i+=(mid<<1)) {
            for(ll j=0,w=1;j<mid;++j,w=mul(w,Wn)) {
                ll x=a[i+j],y=mul(w,a[i+j+mid]);
                a[i+j]=(x+y)%mod;
                a[i+j+mid]=(x+mod-y)%mod;
            }
        }
    }
    if(type==-1) {
        reverse(&a[1],&a[limit]);
        ll inv=q_pow(limit,mod-2);
        for(ll i=0;i<=limit;++i) a[i]=mul(a[i],inv);
    }
}
void Euler(ll b) {
    for(ll i=2;i<=b;++i)  {
        if(!vis[i]) {
            for(ll j=i+i;j<=b;j+=i) 
                vis[j]=1;
        }
    }
}       
int main() {
    Euler(50000);
    while(233) {
        ll a=read(),b=read(),c=read();
        if(!a&&!b&&!c) break;
        memset(A,0,sizeof(A));
        ll limit=1,l=0;
        for(ll i=2;i<=b;++i) A[0][i]=A[1][i]=A[2][i]=A[3][i]=vis[i];
        for(ll i=1;i<=c;++i) {
            ll x=read();
            if(s=='S') A[0][x]=0;
            else if(s=='H') A[1][x]=0;
            else if(s=='C') A[2][x]=0;          
            else A[3][x]=0;
        }
        while(limit<=4LL*b) limit<<=1,l++;
        for(ll i=0;i<=limit;++i)
            r[i]=(r[i>>1]>>1)|((i&1)<<(l-1));
        ntt(A[0],limit,1),ntt(A[1],limit,1),ntt(A[2],limit,1),ntt(A[3],limit,1);
        for(ll i=0;i<=limit;++i) A[0][i]=mul(mul(A[0][i],A[1][i]),mul(A[2][i],A[3][i]));
        ntt(A[0],limit,-1);
        for(ll i=a;i<=b;++i) printf("%lld\n",A[0][i]);
        puts("");
    }
    return 0;
}
全部评论

相关推荐

程序员牛肉:1.大头肯定是院校问题,这个没啥说的。 2.虽然有实习,但是实习的内容太水了,在公司待了七个月的时间,看起来就只做了jwt和接入redis。爬取新闻,数据导入。这几个需求值得你做七个月吗?这不就是三四个月的工作量吗?我要是面试官的话真心会认为你能力不太行。所以既然有实习了,一定要好好写,像是Swagger这种东西是真没必要写上去,就拉一个包的事情。 3.我个人觉得话,在校生不要把自己当社招看,除非你的项目是特别牛逼,特别有名的含金量,否则不要写这种密密麻麻的一串子工作职责。你的项目只有一个作用,就是供面试官从中来抽取八股对你进行拷打。 但是你现在这个看不来什么技术点,可以改一下,详细表述一下你用什么技术实现了什么功能,在实现这个功能的过程中,你解决了什么难题。
点赞 评论 收藏
分享
ALEX_BLX:虾皮好像去年秋招就很抽象,根本不知道要人的标准是啥,而且即使hr面完了也有可能泡不出来池子
投递深圳虾皮信息科技有限公司等公司10个岗位
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务