傳送門
題意好像說的不太清楚?
這題不剪枝樣例都跑不過。。。
Solution
只要預處理一個數組
數組b[i]表示當前數列最大值爲i時,還需要的最小長度
b[i]=b[i<<1]+1
Code
// by spli
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<iostream>
using namespace std;
int n;
int a[105],b[220];
int ans,r[105];
bool flag;
void dfs(int k){
if(k+b[a[k]]>=ans) return;
if(a[k]==n){
ans=k;
for(int i=0;i<=k;++i) r[i]=a[i];
return;
}
for(int i=k;i>=0;--i)
for(int j=i;j>=0;--j)
if(a[i]+a[j]<=n){
if(a[i]+a[j]<a[k]) break;
a[k+1]=a[i]+a[j];
dfs(k+1);
//if(flag) return;
}
}
int main(){
a[0]=1;
while(scanf("%d",&n)&&n){
for(int i=n;i<=n*2;++i) b[i]=0;
for(int i=n-1;i>=1;--i) b[i]=b[i<<1]+1;
flag=0;ans=0x3f3f3f3f;
dfs(0);
for(int i=0;i<=ans;++i) cout<<r[i]<<" ";cout<<endl;
}
return 0;
}