4745 跑步
发布时间:2023年12月29日
#include<bits/stdc++.h>
using namespace std;
long long f[100005];
int a(int x)
{
return (3*x*x-x)/2;
}
int main()
{
int n,p;
cin>>n>>p;
f[0]=1;
for(int i=1;i<=n;i++)
for(int j=1;;j++)
{
int x=a(j),y=a(-j);
if(x<=i)
f[i]=((f[i]+(j&1?1:-1)*f[i-x])%p+p)%p;
if(y<=i)
f[i]=((f[i]+(j&1?1:-1)*f[i-y])%p+p)%p;
if(x>i||y>i)break;
}
cout<<f[n]<<endl;
return 0;
}
文章来源:https://blog.csdn.net/wuwuwu2021/article/details/135298546
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:chenni525@qq.com进行投诉反馈,一经查实,立即删除!