社区讨论
求帮,要傻了
P1990覆盖墙壁参与者 2已保存回复 3
讨论操作
快速查看讨论及其快照的属性,并进行相关操作。
- 当前回复
- 3 条
- 当前快照
- 1 份
- 快照标识符
- @lo17f5jh
- 此快照首次捕获于
- 2023/10/22 16:25 2 年前
- 此快照最后确认于
- 2023/11/02 16:05 2 年前
CPP
#include<stdio.h>
using namespace std;
int main(){
long long n;
scanf("%d",&n);
long long f[n+1],g[n+1];
f[0]=1;
f[1]=1;
f[2]=2;
f[3]=5;
g[3]=1;//g代表当最后一个是L时的情况(未乘2),具体如下。
for(int i=4;i<=n;++i)
{
f[i]=f[i-1]+f[i-2]+2*g[i-1];
/*公式推导:
若令g[n-1]=f[n-3]+f[n-4]+...f[0];
则g[n]=f[n-2]+g[n-1]-f[0];*/
g[i]=f[i-2]+g[i-1]-1;
}
printf("%lld",f[n]%10000);
return 0;
}```
求各位大佬看看究竟哪有问题,想不懂。
回复
共 3 条回复,欢迎继续交流。
正在加载回复...