zoukankan      html  css  js  c++  java
  • bzoj 4555: [Tjoi2016&Heoi2016]求和

    都不知道什么是第二类斯特林数,然后就给了个式子,tmd谁知道这个式子什么意思,我哪知道这个式子怎么推通项之类的,mdzz。吐槽完。

    第二类斯特林数的意义就是从n个数里选出m个集合(集合应该是非空的)

    知道了这个之后就好多了。

    我们可以用容斥来搞一下。贴个百度:http://baike.baidu.com/link?url=IMY-lzOVSGvZlRvKKm88B_jQn4suc_so5tXBu5gtTnkRROHcMRpgju4dgvssfRQO5iqtju8hAOMGSu-ifTvyF9yNl7YSHV8IUvX0_vQ8aZPiBctKLC1Vmam8Rsfup_31#3_2

    有了这个东西,就好多了

    本蒟蒻写字丑,勿喷

     1 #include <cstdio>
     2 #include <cstring>
     3 #include <cmath>
     4 #include <algorithm>
     5 #include <iostream>
     6 #define LL long long
     7 using namespace std;
     8 
     9 const int mod=998244353,G=3,maxn=(1<<18)+5;
    10 
    11 LL ksm(LL a, LL p)
    12 {
    13     LL sum=1;
    14     for (;p;p>>=1,a=a*a%mod)
    15         if (p&1) sum=sum*a%mod;
    16     return sum;
    17 }
    18 
    19 int N,rev[maxn];
    20 void init(int n)
    21 {
    22     int L=0;
    23     for (N=1; N<n; N<<=1) L++;
    24     for (int i=0; i<N; i++) rev[i]=(rev[i>>1]>>1)|((i&1)<<(L-1));
    25 }
    26 void DFT(LL *a, int f)
    27 {
    28     for (int i=0; i<N; i++) if (i<rev[i]) swap(a[i],a[rev[i]]);
    29     for (int h=2; h<=N; h<<=1)
    30     {
    31         LL wn=ksm(G,f==1?(mod-1)/h:mod-1-(mod-1)/h);
    32         for (int i=0; i<N; i+=h)
    33         {
    34             LL w=1;
    35             for (int j=0; j<(h>>1); j++,w=w*wn%mod)
    36             {
    37                 LL x=a[i+j],y=w*a[i+j+(h>>1)]%mod;
    38                 a[i+j]=(x+y)%mod; a[i+j+(h>>1)]=(x-y+mod)%mod;
    39             }
    40         }
    41     }
    42     if (f==-1){
    43         LL inv_N=ksm(N,mod-2);
    44         for (int i=0; i<N; i++) a[i]=a[i]*inv_N%mod;
    45     }
    46 }
    47 void mul(LL *a, LL *b)
    48 {
    49     DFT(a,1); DFT(b,1);
    50     for (int i=0; i<N; i++) a[i]=a[i]*b[i]%mod;
    51     DFT(a,-1);
    52 }
    53 
    54 int n;
    55 LL inv[maxn], fac[maxn], facinv[maxn];
    56 LL a[maxn], b[maxn];
    57 
    58 int main()
    59 {
    60     cin>>n;
    61     inv[1]=1; fac[0]=facinv[0]=1;
    62     for (int i=1; i<=n; i++)
    63     {
    64         if (i!=1) inv[i]=(mod-mod/i)*inv[mod%i]%mod;
    65         fac[i]=fac[i-1]*i%mod;
    66         facinv[i]=facinv[i-1]*inv[i]%mod;
    67     }
    68     a[0]=1; b[0]=1; b[1]=n+1;
    69     for (int i=1; i<=n; i++) a[i]=(i&1?-1:1)*facinv[i];
    70     for (int i=2; i<=n; i++) b[i]=(ksm(i,n+1)-1)*inv[i-1]%mod*facinv[i]%mod;
    71     init(2*n+1); mul(a,b);
    72     LL ans=0;
    73     for (int i=0; i<=n; i++) ans+=ksm(2,i)*fac[i]%mod*a[i]%mod,ans=(ans+mod)%mod;
    74     cout<<ans<<endl;
    75     return 0;
    76 }
    77 /*
    78 #include<bits/stdc++.h>
    79 using namespace std;
    80 int s[15][15];
    81 int main()
    82 {
    83     for (int i=0; i<=10; i++) s[i][i]=1;
    84     for (int i=1; i<=10; i++)
    85         for (int j=1; j<i; j++)
    86             s[i][j]=s[i-1][j]*j+s[i-1][j-1];
    87     for (int i=1; i<=10; i++,cout<<endl)
    88         for (int j=1; j<=i; j++)
    89             cout<<s[i][j]<<" ";
    90     return 0;
    91 }*/
  • 相关阅读:
    C++中的指针和数组
    windows系统下JDK1.6环境变量配置
    Java Reflection (JAVA反射)
    转载:cin深入分析(下) – cin的错误处理
    OpenGL总结
    OpenGL纹理
    c/C++内存分配
    转载:cin深入分析(上) – cin输入操作处理
    c++中string的用法
    OpenGL颜色
  • 原文地址:https://www.cnblogs.com/ccd2333/p/6732576.html
Copyright © 2011-2022 走看看