码迷,mamicode.com
首页 > 其他好文 > 详细

UVA - 1374 Power Calculus

时间:2015-06-11 09:37:52      阅读:118      评论:0      收藏:0      [点我收藏+]

标签:

题目大意:给出 n,问说至少计算几步得到 x^n。

解题思路:迭代深搜,枚举步数,然后深搜判断是否可行。需要优化,当当前数 now 按照最大方案执行后仍然小于 n,则说明不可行。


#include <cstdio>
int n, MAX, A[35];

bool DFS(int cur, int now){
    if (cur > MAX || now <= 0 || now << (MAX - cur) < n)
        return false;
    if (now == n || now << (MAX - cur) == n)
        return true;

    A[cur] = now;
    for (int i = 0; i <= cur; ++i) {
        if (DFS(cur + 1, now + A[i]))
            return true;
        if (DFS(cur + 1, now - A[i]))
            return true;
    }

    return false;
}

int main() {
    while (scanf("%d", &n), n) {
        for (MAX = 0; !DFS(0, 1); ++MAX);
        printf("%d\n", MAX);
    }
    return 0;
}

UVA - 1374 Power Calculus

标签:

原文地址:http://blog.csdn.net/kl28978113/article/details/46446567

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!