标签:
题意:给出一个数字x,然后n = 1,每次计算可以让n翻倍,或者加或减之前x计算得过的数,问至少经过几次计算可以让n等于x。
题解:枚举次数,然后dfs是否能在这个次数得到x。
#include <stdio.h>
const int N = 100;
int x, s[N];
bool dfs(int cur, int num, int pre) {
if (cur == num && pre == x)
return true;
if (cur >= num || pre > 1000 || pre <= 0)
return false;
if (pre << (num - cur) < x)
return false;
for (int i = 0; i < cur; i++) {
s[cur] = s[i] + pre;
if (dfs(cur + 1, num, s[cur]))
return true;
s[cur] = pre - s[i];
if (dfs(cur + 1, num, s[cur]))
return true;
}
return false;
}
int main() {
while (scanf("%d", &x) == 1 && x) {
s[0] = 1;
for (int i = 1;; i++) {
if (dfs(1, i, 1)) {
printf("%d\n", i - 1);
break;
}
}
}
return 0;
}
标签:
原文地址:http://blog.csdn.net/hyczms/article/details/45545807