4745 跑步

cpp 复制代码
#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;
}
相关推荐
leaves falling1 天前
C/C++ const:修饰变量和指针的区别(和引用底层关系)
c语言·开发语言·c++
网域小星球1 天前
C 语言从 0 入门(十二)|指针与数组:数组名本质、指针遍历数组
c语言·算法·指针·数组·指针遍历数组
Tairitsu_H1 天前
C语言:排序(一)
c语言·数据结构·排序
tod1131 天前
深入解析ext2文件系统架构
linux·服务器·c++·文件系统·ext
不想写代码的星星1 天前
C++ 类型萃取:重生之我在幼儿园修炼类型学
c++
比昨天多敲两行1 天前
C++11新特性
开发语言·c++
冰糖拌面1 天前
二叉树遍历-递归、迭代、Morris
算法
xiaoye-duck1 天前
【C++:C++11】核心特性实战:详解C++11列表初始化、右值引用与移动语义
开发语言·c++·c++11
睡一觉就好了。1 天前
二叉搜索树
c++
碧海银沙音频科技研究院1 天前
虚拟机ubuntu与windows共享文件夹(Samba共享)解决WSL加载SI工程满卡问题
人工智能·深度学习·算法