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;
    }
  • 相关阅读:
    iOS 组件化方案
    iOS 核心动画概览
    iOS @字面量
    iOS id 和 instancetype 的区别
    C++ 中的 const
    iOS 开发资料
    iOS 架构-App组件化开发
    iOS 知名大牛的一些博客
    iOS 键盘 隐藏系统的 toolBar
    iOS UIView 单独设置一个角为圆角,两个 三个角也行
  • 原文地址:https://www.cnblogs.com/charlesss/p/10463207.html
Copyright © 2011-2022 走看看