OpenJudge百炼-2692-假币问题-C语言-枚举
来源:互联网 发布:函数式编程的优点 编辑:程序博客网 时间:2024/05/19 22:28
描述:
赛利有12枚银币。其中有11枚真币和1枚假币。假币看起来和真币没有区别,但是重量不同。但赛利不知道假币比真币轻还是重。于是他向朋友借了一架天平。朋友希望赛利称三次就能找出假币并且确定假币是轻是重。例如:如果赛利用天平称两枚硬币,发现天平平衡,说明两枚都是真的。如果赛利用一枚真币与另一枚银币比较,发现它比真币轻或重,说明它是假币。经过精心安排每次的称量,赛利保证在称三次后确定假币。
输入:
第一行有一个数字n,表示有n组测试用例。
对于每组测试用例:
输入有三行,每行表示一次称量的结果。赛利事先将银币标号为A-L。每次称量的结果用三个以空格隔开的字符串表示:天平左边放置的硬币 天平右边放置的硬币 平衡状态。其中平衡状态用``up'', ``down'', 或 ``even''表示, 分别为右端高、右端低和平衡。天平左右的硬币数总是相等的。
输出:
输出哪一个标号的银币是假币,并说明它比真币轻还是重(heavy or light)。
样例输入:
1
ABCD EFGH even
ABCI EFJK up
ABIJ EFGH even
样例输出:
K is the counterfeit coin and it is light.
/***************************************************文件名:百炼-2692**Copyright (c) 2015-2025 OrdinaryCrazy**创建人:OrdinaryCrazy**日期:20170814**描述:百炼2692参考答案**版本:1.0**************************************************/#include <stdio.h>#include <string.h>char left[3][7],right[3][7],result[3][5];/***************************************************函数名:f**输入:c-硬币编号,heavy-需要判断的状态,1表示假币重,0表示假币轻**输出:这种情况成立则输出1,否则输出0**************************************************/int f(char c,int heavy){ int i; for(i = 0;i < 3;i++) switch(result[i][0]) { case 'e' : if(strchr(right[i],c) != NULL || strchr(left[i],c) != NULL) return 0; break; case 'u' : if(heavy) {if(strchr(left[i],c) == NULL) return 0;} else {if(strchr(right[i],c) == NULL) return 0;} break; case 'd' : if(heavy) {if(strchr(right[i],c) == NULL) return 0;} else {if(strchr(left[i],c) == NULL) return 0;} break; } return 1;}int main(){ int n,i; char c; scanf("%d",&n); while(n--) { for(i = 0;i < 3;i++) scanf("%s%s%s",left[i],right[i],result[i]); for(c = 'A';c < 'M';c++) { if(f(c,1)) { printf("%c is the counterfeit coin and it is heavy.\n",c); break; } if(f(c,0)) { printf("%c is the counterfeit coin and it is light.\n",c); break; } } } return 0;}
阅读全文
0 0
- OpenJudge百炼-2692-假币问题-C语言-枚举
- OpenJudge百炼-2811-熄灯问题-C语言-枚举
- OpenJudge百炼-2787-算24-C语言-枚举
- OpenJudge百炼-2747-数字方格-C语言-枚举
- OpenJudge百炼-2964-日历问题-C语言-日期处理
- OpenJudge百炼-2812-恼人的青蛙-C语言-枚举与剪枝
- OpenJudge百炼-2793-孙子问题-C语言-大衍求一术解一般同余方程组
- OpenJudge百炼-2974-487-3279-C语言-字符串处理
- OpenJudge百炼-2744-子串-C语言-字符串处理
- OpenJudge百炼-2712-细菌繁殖-C语言-日期处理
- OpenJudge百炼-2965-玛雅历-C语言-日期处理
- OpenJudge百炼-2966-时区转换-C语言-日期处理
- OpenJudge百炼-2950-摘花生-C语言
- OpenJudge百炼-2745-显示器-C语言-模拟
- OpenJudge百炼-1833-排列-C语言-模拟
- OpenJudge百炼-2706-麦森数-C语言-高精度计算
- OpenJudge百炼-2785-武林-C语言-模拟
- OpenJudge百炼-2803-碎纸机-C语言-递归
- 剑指offer之变态跳台阶
- web.xml不同版本约束
- 2.常用控件:AutoCompleteTextView
- 【C++】try 语句捕获异常,catch子句处理异常
- 信息安全第四篇(加密解密及安全网络通信模型)
- OpenJudge百炼-2692-假币问题-C语言-枚举
- 异常在该控件上执行的操作正从错误的线程调用。使用 Control.Invoke 或 Control.BeginInvoke 封送到正确的线程才能执行此操作。
- struts2--struts2国际化(使用占位符)
- NSQ简介
- Java 多线程卖票例子
- Codeforce_832B_Petya and Exam_字符串模拟
- 配置多个数据源
- 剑指offer-13:在O(1)时间删除链表结点
- 欢迎使用CSDN-markdown编辑器