zoukankan      html  css  js  c++  java
  • luogu3月月赛T2 回忆京都

    京都传送门


    这题emmm怎么不管瞎搞只要维护下前缀和就能过,感觉并没有T1难,细节除了取模常规操作也没啥别的。一次切很快乐(滑稽)

    组合数怎么瞎搞都行(lucas除外),然后二维前缀和维护一波即可。

    代码如下:

    #include<iostream>
    #include<cstdio>
    #include<cmath>
    #include<cstring>
    #define ll long long
    #define mo 19260817
    #define maxn 1005
    long long jc[maxn],f[maxn][maxn],sum[maxn][maxn];
    using namespace std;
    ll exgcd(ll l,ll r,ll &x,ll &y)
    {
        if(r==0)
        {
            x=1;
            y=0;
            return l;
        }
        else
        {
            ll d=exgcd(r,l%r,y,x);
            y-=l/r*x;
            return d;
        }
    }
    ll int aha(ll w)
    {
        ll x,y;
        ll r=exgcd(w,mo,x,y)%mo;
        return(x%mo+mo)%mo;
    }
    void weihu()
    {
        jc[0]=1;jc[1]=1;
        for(int i=1;i<=1000;i++)
        {
            jc[i]=(jc[i-1]%mo*i%mo)%mo;
        }
        for(int i=1;i<=1000;i++)
        {
            for(int j=1;j<=i;j++)
                f[i][j]=jc[i]%mo*aha(jc[j]%mo*jc[i-j]%mo)%mo;
        }
        for(int i=1;i<=1000;i++)
        {
            for(int j=1;j<=1000;j++)
                sum[i][j]=(((sum[i-1][j]-sum[i-1][j-1]+mo)%mo+sum[i][j-1])%mo+f[i][j])%mo;
        }
    }
    int main()
    {
        int q;
        scanf("%d",&q);
        weihu();
        while(q--)
        {
            int n,m;
            scanf("%d%d",&n,&m);
            cout<<sum[m][n]<<endl;
        }
        return 0;
    }
  • 相关阅读:
    总结面试常见题
    关于面试
    关于SQL经典题
    阶乘
    异常处理——捕获并抛出
    异常处理——异常越界
    异常处理——创建抛出
    输出异常
    抛出异常
    异常处理
  • 原文地址:https://www.cnblogs.com/charlesss/p/10463207.html
Copyright © 2011-2022 走看看