九度OJ 1150:Counterfeit Dollar(假美元) (分析、检验)
时间限制:1 秒
内存限制:32 兆
特殊判题:否
提交:485
解决:215
- 题目描述:
-
Sally Jones has a dozen Voyageur silver dollars. However, only eleven of the coins are true silver dollars; one coin is counterfeit even though its color and size make it indistinguishable from the real silver dollars. The counterfeit coin has a different
weight from the other coins but Sally does not know if it is heavier or lighter than the real coins.
Happily, Sally has a friend who loans her a very accurate balance scale. The friend will permit Sally three weighings to find the counterfeit coin. For instance, if Sally weighs two coins against each other and the scales balance then she knows these two
coins are true. Now if Sally weighs one of the true coins against a third coin and the scales do not balance then Sally knows the third coin is counterfeit and she can tell whether it is light or heavy depending on whether the balance on which it is placed
goes up or down, respectively.
By choosing her weighings carefully, Sally is able to ensure that she will find the counterfeit coin with exactly three weighings.
- 输入:
-
For each case, the first line of input is an integer n (n > 0) specifying the number of cases to follow. Each case consists of three lines of input, one for each weighing. Sally has identified each of the coins with the letters A--L. Information on a weighing
will be given by two strings of letters and then one of the words ``up'', ``down'', or ``even''. The first string of letters will represent the coins on the left balance; the second string, the coins on the right balance. (Sally will always place the same
number of coins on the right balance as on the left balance.) The word in the third position will tell whether the right side of the balance goes up, down, or remains even.
- 输出:
-
For each case, the output will identify the counterfeit coin by its letter and tell whether it is heavy or light. The solution will always be uniquely determined.
- 样例输入:
-
1
ABCD EFGH even
ABCI EFJK up
ABIJ EFGH even
- 样例输出:
-
K is the counterfeit coin and it is light.
思路:
简单的说,有12枚硬币,1枚是假的,重量与其他的不一样,但不知道是重还是轻。有一个天平可以称,只要三次就能找出来。
现在给出三次称的结果,求那一枚是假的,重还是轻。
有两种方法,一种是分析,需要较强的逻辑;还有一种方法我更推荐,直接24种情况代入检验,满足结果即是答案。
我在九度上的AC代码在POJ上未通过,原因是不一定天平两边都是四枚硬币。
代码1是九度上的C代码,代码2是在POJ上的C++代码。
代码1:
#include <stdio.h>
#include <string.h> int c2i(char c)
{
return c-'A';
} char i2c(int i)
{
return i+'A';
} int trans(char s[])
{
if (strcmp(s, "even") == 0)
return 0;
else if (strcmp(s, "up") == 0)
return 1;
else
return -1;
} int main(void)
{
int i, j, k, r;
int n, res[3];
char s1[3][5], s2[3][5], s3[3][5]; while (scanf("%d", &n) != EOF)
{
while (n--)
{
for (i=0; i<3; i++)
{
scanf("%s%s%s", s1[i], s2[i], s3[i]);
res[i] = trans(s3[i]);
}
int flag = 0;;
for (j=-1; j<=1; j+=2)
{
for (k=0; k<12; k++)
{
for (i=0; i<3; i++)
{
int value = 0;
for (r=0; r<4; r++)
{
if (c2i(s1[i][r]) == k)
value = j;
if (c2i(s2[i][r]) == k)
value = -j;
}
if (value != res[i])
break;
}
if (i == 3)
{
flag = 1;
break;
}
}
if (flag == 1)
break;
}
if (j == -1)
printf("%c is the counterfeit coin and it is light.\n", i2c(k));
else
printf("%c is the counterfeit coin and it is heavy.\n", i2c(k));
}
} return 0;
}
/**************************************************************
Problem: 1150
User: liangrx06
Language: C
Result: Accepted
Time:0 ms
Memory:912 kb
****************************************************************/
代码2:
#include <stdio.h>
#include <string.h> int c2i(char c)
{
return c-'A';
} char i2c(int i)
{
return i+'A';
} int trans(char s[])
{
if (strcmp(s, "even") == 0)
return 0;
else if (strcmp(s, "up") == 0)
return 1;
else
return -1;
} int main(void)
{
int i, j, k, r;
int n, res[3];
char s1[3][5], s2[3][5], s3[3][5]; while (scanf("%d", &n) != EOF)
{
while (n--)
{
for (i=0; i<3; i++)
{
scanf("%s%s%s", s1[i], s2[i], s3[i]);
res[i] = trans(s3[i]);
}
int flag = 0;;
for (j=-1; j<=1; j+=2)
{
for (k=0; k<12; k++)
{
for (i=0; i<3; i++)
{
int value = 0;
for (r=0; r<4; r++)
{
if (c2i(s1[i][r]) == k)
value = j;
if (c2i(s2[i][r]) == k)
value = -j;
}
if (value != res[i])
break;
}
if (i == 3)
{
flag = 1;
break;
}
}
if (flag == 1)
break;
}
if (j == -1)
printf("%c is the counterfeit coin and it is light.\n", i2c(k));
else
printf("%c is the counterfeit coin and it is heavy.\n", i2c(k));
}
} return 0;
}
/**************************************************************
Problem: 1150
User: liangrx06
Language: C
Result: Accepted
Time:0 ms
Memory:912 kb
****************************************************************/
九度OJ 1150:Counterfeit Dollar(假美元) (分析、检验)的更多相关文章
- 【九度OJ】题目1040:Prime Number 解题报告
[九度OJ]题目1040:Prime Number 解题报告 标签(空格分隔): 九度OJ 原题地址:http://ac.jobdu.com/problem.php?pid=1040 题目描述: Ou ...
- 九度oj 题目1087:约数的个数
题目链接:http://ac.jobdu.com/problem.php?pid=1087 题目描述: 输入n个整数,依次输出每个数的约数的个数 输入: 输入的第一行为N,即数组的个数(N<=1 ...
- 九度OJ 1502 最大值最小化(JAVA)
题目1502:最大值最小化(二分答案) 九度OJ Java import java.util.Scanner; public class Main { public static int max(in ...
- 九度OJ,题目1089:数字反转
题目描述: 12翻一下是21,34翻一下是43,12+34是46,46翻一下是64,现在又任意两个正整数,问他们两个数反转的和是否等于两个数的和的反转. 输入: 第一行一个正整数表示测试数据的个数n. ...
- 九度OJ 1500 出操队形 -- 动态规划(最长上升子序列)
题目地址:http://ac.jobdu.com/problem.php?pid=1500 题目描述: 在读高中的时候,每天早上学校都要组织全校的师生进行跑步来锻炼身体,每当出操令吹响时,大家就开始往 ...
- 九度OJ 1531 货币面值(网易游戏2013年校园招聘笔试题) -- 动态规划
题目地址:http://ac.jobdu.com/problem.php?pid=1531 题目描述: 小虎是游戏中的一个国王,在他管理的国家中发行了很多不同面额的纸币,用这些纸币进行任意的组合可以在 ...
- 九度OJ 1024 畅通工程 -- 并查集、贪心算法(最小生成树)
题目地址:http://ac.jobdu.com/problem.php?pid=1024 题目描述: 省政府"畅通工程"的目标是使全省任何两个村庄间都可以实现公路交通(但 ...
- 九度OJ 1371 最小的K个数 -- 堆排序
题目地址:http://ac.jobdu.com/problem.php?pid=1371 题目描述: 输入n个整数,找出其中最小的K个数.例如输入4,5,1,6,2,7,3,8这8个数字,则最小的4 ...
- 九度OJ 题目1384:二维数组中的查找
/********************************* * 日期:2013-10-11 * 作者:SJF0115 * 题号: 九度OJ 题目1384:二维数组中的查找 * 来源:http ...
随机推荐
- addEventListener与attachEvent
一.attachEvent和addEventListener (一)addEventListener addEventListener() 方法用于向指定元素添加事件句柄.使用 removeEvent ...
- Oracle的隔离级别
隔离级别(isolation level) 隔离级别定义了事务与事务之间的隔离程度. 隔离级别与并发性是互为矛盾的:隔离程度越高,数据库的并发性越差:隔离程度越低,数据库的并发性越 ...
- ArcGIS 10.2 二次开发,兼容Visual Studio 2012二次开发,完美安装教程
GIS 经常安装是常有的事,每次重装系统都要浪费大半天去安装这个.所以凑这一次安装,把这个软件重新安装的步骤整理了一下,希望对大家有所帮助.这次整理的内容的关键优点是,对常见的出错内容进行了归纳整理. ...
- Android 两种注册、发送广播的区别
前言:前面文章记录了Service的使用,这次来记录另一个四个组件之一的BroadcastReceiver.主要介绍两种发送和注册广播的区别. BroadcastReceiver广播接收者用于接收系统 ...
- 七天学会ASP.NET MVC (二)——ASP.NET MVC 数据传递 【转】
http://www.cnblogs.com/powertoolsteam/p/MVC_two.html 通过第一天的学习之后,我们相信您已经对MVC有一些基本了解. 本节所讲的内容是在上节的基础之上 ...
- Shell脚本部分语法
Shell中的变量 Linux Shell中的变量分为“系统变量”和“用户自定义变量”,可以通过set命令查看那系统变量 系统变量:$HOME.$PWD.$SHELL.$USER等等 显示当前sh ...
- MAT使用及OOM分析
知识及工具推荐 1.Android资源监控工具 2.Android内存管理机制 http://blog.csdn.net/hexieshangwang/article/details/47188987
- mbr 备份
MBR共512字节 (1) 第1-446字节:调用操作系统的机器码. (2) 第447-510字节:分区表(Partition table). (3) 第511-512字节:主引导记录签名(0x55和 ...
- iOS开发中地图与定位
不管是QQ还是微信的移动client都少不了定位功能,之前在微信demo中没有加入定位功能,今天就写个定位的小demo来了解一下定位和地图的东西. 地图和定位看上去是挺高大上一东西.其有使用方法比Ta ...
- Java reference的种类及使用场景
Java 中一共有 4 种类型的引用 : StrongReference. SoftReference. WeakReference 以及 PhantomReference (传说中的幽灵引用).这 ...