称硬币(中国大学mooc算法设计与分析(二))习题练习

原视频:程序设计与算法(二)算法基础_中国大学MOOC(慕课) (icourse163.org)

#include <iostream>
#include <cstring>
using namespace std;

char Left[3][7]; // 存放左侧硬币
char Right[3][7];//存放右侧硬币
char result[3][7];//存放右边天平的结果
bool IsFake(char c, bool light);

int main()
{
    //输入组数
    int n;
    cin >> n;
    while(n--)
    {
        //输入左侧硬币、右侧硬币和结果
        for(int i = 0; i < 3; i++)
        {
            cin >> Left[i] >> Right[i] >> result[i];
        }
        //从硬币A到硬币L便利猜测
        for(char c = 'A'; c < 'L'; c++)
        {
            //先猜测硬币是轻的,调用IsFake函数可以通过比较判断c是否为假币
            if(IsFake(c, true))
            {
                cout << c << "是轻的假币\n";
                break;
            }
            else if(IsFake(c, false))
            {
                cout << c << "是重的假币\n";
                break;
            }
        }

    }
    return 0;
}

//判断猜测的硬币是否为假币,第一个参数为硬币编号、第二个参数为是轻(true)还是重(false)
bool IsFake(char c, bool light)
{

    //假设假币是轻的,在哪边天平哪边就会起来
    for(int i = 0; i < 3; i++)
    {
        char *PLeft, *PRight;
        //轻的话右侧天平会翘起来
        if(light)
        {
            PLeft = Left[i];
            PRight = Right[i];
        }
        //重的话反向设置
        else
        {
            PLeft = Right[i];
            PRight = Left[i];
        }
        switch(result[i][0])
        {
            //如果右边升高了,假币轻的话就是右侧,重的话就是在左侧
            //但前面我们将重的结果调换了,所以都是在PRight中
            case 'u':
                if(strchr(PRight, c) == NULL)
                    return false;
                break;
            //如果平的,那么所有的编号都是真币
            case 'e':
                if(strchr(PLeft, c) || strchr(PRight, c))
                    return false;
                break;

            //右边下降了就是轻的在左侧,或者重的在右侧,同上
            case 'd':
                if(strchr(PLeft, c) == NULL)
                    return false;
                break;
        }
    }
    //执行到这说明符合条件,返回true
    return true;
}
/*1
ABCD EFGH even
ABCI EFJK up
ABIJ EFGH even*/

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

百年bd

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值