要求找出具有下列性质的数的个数(包含输入的自然数n):
先输入一个自然数n(n<=500),然后对此自然数按照如下方法进行处理:
1.不作任何处理;
2.在它的左边加上一个自然数,但该自然数不能超过原数字的一半;
3. 加上数后,继续按此规则进行处理,直到不能再加自然数为止.
如输入6,则有6
1626
12636
136
分析:
#include <iostream>
using namespace std;
int comp(int n) {
int ans=1; //n的半数集合的大小,n属于这个集合,因此初值为1
for(i=1;i<=n/2;i++) { //i为新数的前面的部分数字
ans=ans+ comp(i);
}
return ans;
}
int main() {
int x,num;
cin>>x;
num=comp(x);
cout<<num<<endl; return 0;
}
计算半数集问题的递归算法—记忆式搜索(备忘录)
#include <iostream>
using namespace std;
int a[100];
int comp(int n) {
int ans=1;
if(a[n]>0) return a[n];
for(int i=1;i<=n/2;i++) {
ans=ans+ comp(i);
}
a[n]=ans;
return ans;
}
int main() {
int x,num;
memset(a,0,sizeof(a));
cin>>x; num=comp(x); cout<<num<<endl; return 0;
}