1057: 有假币

                               1057: 有假币

时间限制(普通/Java):1000MS/10000MS   运行内存限制:65536KByte
总提交: 2844
      测试通过:773

描述

居然有假币!!! 
事情是这样的,现在猪肉涨了,但是农民的工资却不见涨啊,没钱怎么买猪肉啊。渊子这就去买猪肉,结果找来的零钱中有假币!!!可惜渊子一不小心把它混进了一堆真币里面去了。现在知道假币的重量比真币的质量要轻。给你一个天平,请用最快的时间把那个可恶的假币找出来。

输入

1≤n≤230,输入0结束程序。

输出

最少要称几次一定能把那个假币找出来。

样例输入

3

12

0

样例输出

1

3

提示

示例1中共有3枚硬币,所以任意取2个放天平上称量一下。 
因为假币的重量比较轻。 

    • 如果天平不平衡,则较轻的那枚就是假币。 
    • 如果天平平衡,则说明这两枚硬币都是真的,而剩下那枚是假币。

  考虑分3堆对该问题最优的特点

 

做法一:用到了 log 的用法

         (int)( log (x) / log (3) )

 

#include <stdio.h>

#include <math.h>





int f(int x)

{

    if(1 == x)

        return 0;

    else

        if(2 == x)

            return 1;

    else

        if(3 == x)

            return 1;

    else

        if(x == (pow(3, (int)( log (x) / log (3)))))

            return (log (x) / log (3));

    else

        return (1 + (int)(log (x) / log (3)));

}

 

做法2  就是让分3堆的数尽量平均

    

#include <stdio.h>





int main()

{

    int n;

    while(scanf("%d", &n), n != 0)

    {

        int count = 0;



        while(n != 0)

        {

            if(1 == n)        

                break;

            else

                if(2 == n)

                {

                    count += 1;

                    break;

                }

            else

                if(3 == n)

                {

                    count += 1;

                    break;        

                }

            else

            {

                switch(n % 3)//补充至3堆平均,既取原来分堆后最大的一堆

                {

                    case 0:    n /= 3;break;

                    case 1:    n = (n + 2) / 3;break;

                    case 2: n = (n + 1) / 3;break;

                }

                count++;

            }

        }

        printf("%d\n", count);

    

    }



    return 0;

}

 

补充一个看到的函数

      

函数名: ceil

用 法: double ceil(double x);

功 能: 返回大于或者等于指定表达式的最小整数

头文件:math.h

中文名

 ceil

    

 double ceil

    

返回大于等于表达式的最小整数

头文件

math.h

  对第一种解法的简化

   

#include<stdio.h>

#include<math.h>

int main()

{
int n; while(scanf("%d",&n),n != 0) printf("%.0lf\n",ceil(log(n)/log(3.0)));//0.1f很重要 return 0; }

你可能感兴趣的:(1057: 有假币)