数的计算 题解
2023-08-27 09:21:37
发布于:广东
14阅读
0回复
0点赞
这道题写出前几项后会发现是有规律可循的:
首先规定 f[1]=1;
f[2]=f[1]+1;
f[3]=f[1]+1;
f[4]=f[1]+f[2]+1;
f[5]=f[1]+f[2]+1;
f[6]=f[1]+f[2]+f[3]+1;
f[7]=f[1]+f[2]+f[3]+1;
…
f[n]=f[1]+…+f[n/2];
每一次都由1加到n/2;
然后题目中给定n为1000以内,所以双重循环完全可以实现
AC代码
#include<bits/stdc++.h>
using namespace std;
int n;
int f[1001];//记录每个数字的个数
int main()
{
cin>>n;
f[1]=1;
/*
f[1]=1;
f[2]=f[1]+1;
f[3]=f[1]+1;
f[4]=f[1]+f[2]+1;
f[5]=f[1]+f[2]+1;
f[6]=f[1]+f[2]+f[3]+1;
f[7]=f[1]+f[2]+f[3]+1;
......
f[n]=f[1]+...+f[n/2];
*/
//题目最多有1000个数,所以两层循环完全OK
for(int i=1;i<=n;i++){
for(int j=1;j<=i/2;j++){
f[i]+=f[j];
}
if(i>1) f[i]++;
//cout<<"f["<<i<<"]="<<f[i]<<endl;
}
cout<<f[n]<<endl;
return 0;
}
这里空空如也
有帮助,赞一个