| 比赛 | 
    EYOI暨SBOI暑假快乐赛2nd | 
    评测结果 | 
    TTTTTEEEEE | 
    | 题目名称 | 
    幂次计算 | 
    最终得分 | 
    0 | 
    | 用户昵称 | 
    ムラサメ | 
    运行时间 | 
    5.819 s  | 
    | 代码语言 | 
    C++ | 
    内存使用 | 
    5.74 MiB  | 
    | 提交时间 | 
    2022-06-26 10:55:21 | 
显示代码纯文本
#include<bits/stdc++.h>
using namespace std;
int n,ans;
int a[1010];
void dfs(int x,int cnt){
	if(x==n){
		ans=min(ans,cnt);
		return;
	}
	a[cnt]=x;
	for(int i=0;i<=cnt;i++){
		if(cnt+1<ans){
			dfs(x+a[i],cnt+1);
			dfs(abs(x-a[i]),cnt+1);
		}
	}
}
int main(){
	freopen("mico.in","r",stdin);
	freopen("mico.out","w",stdout);
	for(;;){
		cin>>n;
		if(n==0){
			return 0;
		}
		memset(a,0,sizeof(a));
		ans=0x7f7f7f7f7f7f;
		dfs(1,0);
		cout<<ans<<endl;
	}
	return 0;
}