题目描述 赛利有12枚银币。其中有11枚真币和1枚假币。假币看起来和真币没有区别,但是重量不同。但赛利不知道假币比真币轻还是重。于是他向朋友借了一架天平。朋友希望赛利称三次就能找出假币并且确定假币是轻是重。例如:如果赛利用天平称两枚硬币,发现天平平衡,说明两枚都是真的。如果赛利用一枚真币与另一枚银币比较,发现它比真币轻或重,说明它是假币。经过精心安排每次的称量,赛利保证在称三次后确定假币。输入 第一行有一个数字n,表示有n组测试数据。对于每组测试数据: 输入有三行,每行表示一次称量的结果。赛利事先将银币标号为A-L。每次称量的结果用三个以空格隔开的字符串表示:天平左边放置的硬币 天平右边放置的硬币 平衡状态。其中平衡状态用“up”, “down”, 或 “even”表示, 分别为右端高、右端低和平衡。天平左右的硬币数总是相等的。输出 输出哪一个标号的银币是假币,并说明它比真币轻还是重(重或轻)。样例输入 复制 1 ABCD EFGH even ABCI EFJK up ABIJ EFGH even 样例输出 复制 K 是假币,它很轻。用C语言写代码

时间: 2023-12-14 12:38:04 浏览: 33
```c #include <stdio.h> #include <string.h> char coins[12]; // 存放硬币状态 char status[5]; // 存放称量结果 // 比较函数,返回值为-1表示轻,1表示重,0表示平衡 int compare(char left[], char right[], char status[]) { int left_sum = 0, right_sum = 0; int len = strlen(left); for (int i = 0; i < len; i++) { left_sum += coins[left[i] - 'A']; right_sum += coins[right[i] - 'A']; } if (left_sum < right_sum) { return strcmp(status, "up") == 0 ? 1 : -1; } else if (left_sum > right_sum) { return strcmp(status, "up") == 0 ? -1 : 1; } else { return 0; } } int main() { int n; scanf("%d", &n); while (n--) { memset(coins, 0, sizeof(coins)); // 初始化 for (int i = 0; i < 3; i++) { char left[5], right[5]; scanf("%s%s%s", left, right, status); if (strcmp(status, "even") == 0) { // 如果是平衡的,那么称量的硬币都是真币 int len = strlen(left); for (int j = 0; j < len; j++) { coins[left[j] - 'A'] = 1; coins[right[j] - 'A'] = 1; } } } // 第三次称量,此时假币已经确定是轻还是重 for (int i = 0; i < 12; i++) { if (coins[i] == 0) { // 如果这枚硬币是假币 coins[i] = -1; // 先假设假币比真币轻 // 检查是否能够确定假币比真币重 if (compare("ABEF", "CDGH", "up") == -1 && // ABEF比CDGH轻 compare("ABEF", "CDGH", "even") == 0 && // ABEF和CDGH平衡 compare("ABEF", "IJKL", "even") == 0 && // ABEF和IJKL平衡 compare("CDGH", "IJKL", "even") == 0 && // CDGH和IJKL平衡 compare("AEIM", "BFJN", "up") == -1 && // AEIM比BFJN轻 compare("AEIM", "BFJN", "even") == 0 && // AEIM和BFJN平衡 compare("AEIM", "CGKO", "even") == 0 && // AEIM和CGKO平衡 compare("BFJN", "CGKO", "even") == 0 && // BFJN和CGKO平衡 compare("AFKP", "BGLQ", "up") == -1 && // AFPK比BGLQ轻 compare("AFKP", "BGLQ", "even") == 0 && // AFPK和BGLQ平衡 compare("AFKP", "CHLQ", "even") == 0 && // AFPK和CHLQ平衡 compare("BGLQ", "CHLQ", "even") == 0) { // BGLQ和CHLQ平衡 coins[i] = 1; // 假币比真币重 } break; } } // 输出结果 for (int i = 0; i < 12; i++) { if (coins[i] == -1) { printf("%c is the counterfeit coin and it is light.\n", i + 'A'); break; } else if (coins[i] == 1) { printf("%c is the counterfeit coin and it is heavy.\n", i + 'A'); break; } } } return 0; } ```

相关推荐

zip
蛋白质耐热温度分类及预测重要数据表蛋白质是生物体中普遍存在的一类重要生物大分子,由天然氨基酸通过肽键连接而成。它具有复杂的分子结构和特定的生物功能,是表达生物遗传性状的一类主要物质。 蛋白质的结构可分为四级:一级结构是组成蛋白质多肽链的线性氨基酸序列;二级结构是依靠不同氨基酸之间的C=O和N-H基团间的氢键形成的稳定结构,主要为α螺旋和β折叠;三级结构是通过多个二级结构元素在三维空间的排列所形成的一个蛋白质分子的三维结构;四级结构用于描述由不同多肽链(亚基)间相互作用形成具有功能的蛋白质复合物分子。 蛋白质在生物体内具有多种功能,包括提供能量、维持电解质平衡、信息交流、构成人的身体以及免疫等。例如,蛋白质分解可以为人体提供能量,每克蛋白质能产生4千卡的热能;血液里的蛋白质能帮助维持体内的酸碱平衡和血液的渗透压;蛋白质是组成人体器官组织的重要物质,可以修复受损的器官功能,以及维持细胞的生长和更新;蛋白质也是构成多种生理活性的物质,如免疫球蛋白,具有维持机体正常免疫功能的作用。 蛋白质的合成是指生物按照从脱氧核糖核酸(DNA)转录得到的信使核糖核酸(mRNA)上的遗传信息合成蛋白质的过程。这个过程包括氨基酸的活化、多肽链合成的起始、肽链的延长、肽链的终止和释放以及蛋白质合成后的加工修饰等步骤。 蛋白质降解是指食物中的蛋白质经过蛋白质降解酶的作用降解为多肽和氨基酸然后被人体吸收的过程。这个过程在细胞的生理活动中发挥着极其重要的作用,例如将蛋白质降解后成为小分子的氨基酸,并被循环利用;处理错误折叠的蛋白质以及多余组分,使之降解,以防机体产生错误应答。 总的来说,蛋白质是生物体内不可或缺的一类重要物质,对于维持生物体的正常生理功能具有至关重要的作用。

最新推荐

recommend-type

HP-Socket编译-Linux

HP-Socket编译-Linux
recommend-type

JavaScript_生活在Discord上的开源社区列表.zip

JavaScript
recommend-type

JavaScript_MultiOn API.zip

JavaScript
recommend-type

JavaScript_简单和完整的React DOM测试工具,鼓励良好的测试实践.zip

JavaScript
recommend-type

JavaScript_成为一个Nodejs开发者.zip

JavaScript
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

可见光定位LED及其供电硬件具体型号,广角镜头和探测器,实验设计具体流程步骤,

1. 可见光定位LED型号:一般可使用5mm或3mm的普通白色LED,也可以选择专门用于定位的LED,例如OSRAM公司的SFH 4715AS或Vishay公司的VLMU3500-385-120。 2. 供电硬件型号:可以使用常见的直流电源供电,也可以选择专门的LED驱动器,例如Meanwell公司的ELG-75-C或ELG-150-C系列。 3. 广角镜头和探测器型号:一般可采用广角透镜和CMOS摄像头或光电二极管探测器,例如Omron公司的B5W-LA或Murata公司的IRS-B210ST01。 4. 实验设计流程步骤: 1)确定实验目的和研究对象,例如车辆或机器人的定位和导航。
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。