CF755G PolandBall and Many Other Balls 题解

一个常数和复杂度都很大的题解


为 在 个球中选 组的方案数,则显然有转移

然后考虑对其优化:
的生成函数,则 只与 有关,且关系为 .
然后考虑对上式进行矩阵加速递推,复杂度 ,再加一个巨大的常数,但此题 的范围很小,可以通过。

代码:

#include<bits/stdc++.h>
using namespace std;
#define pb push_back
#define mp make_pair
#define Fast_IO ios::sync_with_stdio(false);
#define fir first
#define sec second
#define mod 998244353
#define ll long long
inline int read()
{
    char ch=getchar(); int nega=1; while(!isdigit(ch)) {if(ch=='-') nega=-1; ch=getchar();}
    int ans=0; while(isdigit(ch)) {ans=ans*10+ch-48;ch=getchar();}
    if(nega==-1) return -ans;
    return ans;
}
typedef pair<int,int> pii;
int add(int x,int y){return x+y>=mod?x+y-mod:x+y;}
int sub(int x,int y){return x-y<0?x-y+mod:x-y;}
int mul(int x,int y){return 1LL*x*y%mod;}
int qpow(int x,int y)
{
    int ans=1;
    while(y)
    {
        if(y&1) ans=mul(ans,x);
        x=mul(x,x);
        y>>=1;
    }
    return ans;
}
int getInv(int x)
{
    return qpow(x,mod-2);
}
// 略去多项式的板子,以下 vector 即是存储多项式的容器
using namespace Poly;
int n,k;
struct Mat
{
    vector<int> a[3][3];
    void clear()
    {
        for(int i=0;i<3;i++)
        {
            for(int j=0;j<3;j++)
            {
                a[i][j].resize(1);
                a[i][j][0]=0;
            }
        }
    }
};
Mat mul(Mat x,Mat y)
{
    Mat ans; ans.clear();
    for(int i=1;i<=2;i++)
    {
        for(int j=1;j<=2;j++)
        {
            for(int k=1;k<=2;k++)
            {
                ans.a[i][j]=ans.a[i][j]+x.a[i][k]*y.a[k][j];
            }
        }
    }
    for(int i=1;i<=2;i++)
    {
        for(int j=1;j<=2;j++)
        {
            if((int)ans.a[i][j].size()>k+1) ans.a[i][j].resize(k+1);
        }
    }
    return ans;
}
Mat qpow(Mat x,int y)
{
    Mat ans; ans.clear();
    ans.a[1][1]=one,ans.a[2][2]=one;
    while(y)
    {
        if(y&1)
        {
            ans=mul(ans,x);
        }
        x=mul(x,x);
        y>>=1;
    }
    return ans;
}
signed main()
{
    Init_Inv();
    cin>>n>>k;
    Mat a; a.clear();
    a.a[1][2].resize(2); a.a[1][2][1]=1;
    a.a[2][1]=one;
    a.a[2][2].resize(2); a.a[2][2][1]=a.a[2][2][0]=1;
    a=qpow(a,n-1);
    Mat R; R.clear();
    R.a[1][1]=one;
    R.a[1][2].resize(2); R.a[1][2][0]=1,R.a[1][2][1]=1;
    R=mul(R,a);
    vector<int> ans=R.a[1][2];
    ans.resize(k+1);
    for(int i=1;i<=k;i++) printf("%d ",ans[i]); cout<<"\n";
    return 0;
}

全部评论

相关推荐

ProMonkey2024:5个oc?厉害! 但是有一个小问题:谁问你了?😡我的意思是,谁在意?我告诉你,根本没人问你,在我们之中0人问了你,我把所有问你的人都请来 party 了,到场人数是0个人,誰问你了?WHO ASKED?谁问汝矣?誰があなたに聞きましたか?누가 물어봤어?我爬上了珠穆朗玛峰也没找到谁问你了,我刚刚潜入了世界上最大的射电望远镜也没开到那个问你的人的盒,在找到谁问你之前我连癌症的解药都发明了出来,我开了最大距离渲染也没找到谁问你了我活在这个被辐射蹂躏了多年的破碎世界的坟墓里目睹全球核战争把人类文明毁灭也没见到谁问你了(别的帖子偷来的,现学现卖😋)
点赞 评论 收藏
分享
hso_:哈哈哈哈哈哈我没offer一样在同一道题开喷了
投递深圳同为数码等公司10个岗位
点赞 评论 收藏
分享
头像
11-10 15:58
东北大学 Java
ros275229:我还没收到,但是距离上一次面试快一个月了
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务