贪心,打表(或者快速幂), UVA - 11636

题目链接:

https://cn.vjudge.net/problem/34398/origin

题目比较简单,就是水题,基础贪心,大于所需的即可:

AC代码:

打表:

#include 
#include 
#include 
#define ll long long

using namespace std;
const int MX = 50;
ll mp[MX];

void get_table() //打一个2^n的表即可
{
    for(int i = 0; i <= 32; ++i)
    {
        mp[i] = pow(2, i);
    }
}

int main()
{
    int k = 0;
    get_table();
    ll n;
    while(scanf("%lld", &n) != EOF && (n > 0))
    {
        k++;
        for(int i = 0; i <= 32; ++i)
        {
            if(mp[i] >= n) //判断一下,如果2^i大于等于则足够copy完。
            {
                 printf("Case %d: %d\n", k, i);
                 break;
            }

        }
    }
}
View Code

快速幂:

#include 
#include 
#define ll long long

using namespace std;
ll poww(ll a, ll b)
{
    ll ans = 1, base = a;
    while(b)
    {
        if(b&1 != 0)
            ans *= base;
        base *= base;
        b >>= 1;
    }
    return ans;
}


int main()
{
    int k = 0;
    ll n;
    while(scanf("%lld", &n) != EOF && (n > 0))
    {
        k++;
        //printf("%lld\n", poww(2, n));
        if(n == 1)
        {
            printf("Case %d: 0\n", k);
            continue;
        }
        for(int i = 1; i <= 30; ++i)
        {
            if(poww(2, i) >= n)
            {
                printf("Case %d: %d\n", k, i);
                break;
            }
        }
    }
}
View Code

如有疑问,欢迎评论指出!

你可能感兴趣的:(贪心,打表(或者快速幂), UVA - 11636)