时间限制: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.
来源:
2010年北京大学计算机研究生机试真题

思路:

简单的说,有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(假美元) (分析、检验)的更多相关文章

  1. 【九度OJ】题目1040:Prime Number 解题报告

    [九度OJ]题目1040:Prime Number 解题报告 标签(空格分隔): 九度OJ 原题地址:http://ac.jobdu.com/problem.php?pid=1040 题目描述: Ou ...

  2. 九度oj 题目1087:约数的个数

    题目链接:http://ac.jobdu.com/problem.php?pid=1087 题目描述: 输入n个整数,依次输出每个数的约数的个数 输入: 输入的第一行为N,即数组的个数(N<=1 ...

  3. 九度OJ 1502 最大值最小化(JAVA)

    题目1502:最大值最小化(二分答案) 九度OJ Java import java.util.Scanner; public class Main { public static int max(in ...

  4. 九度OJ,题目1089:数字反转

    题目描述: 12翻一下是21,34翻一下是43,12+34是46,46翻一下是64,现在又任意两个正整数,问他们两个数反转的和是否等于两个数的和的反转. 输入: 第一行一个正整数表示测试数据的个数n. ...

  5. 九度OJ 1500 出操队形 -- 动态规划(最长上升子序列)

    题目地址:http://ac.jobdu.com/problem.php?pid=1500 题目描述: 在读高中的时候,每天早上学校都要组织全校的师生进行跑步来锻炼身体,每当出操令吹响时,大家就开始往 ...

  6. 九度OJ 1531 货币面值(网易游戏2013年校园招聘笔试题) -- 动态规划

    题目地址:http://ac.jobdu.com/problem.php?pid=1531 题目描述: 小虎是游戏中的一个国王,在他管理的国家中发行了很多不同面额的纸币,用这些纸币进行任意的组合可以在 ...

  7. 九度OJ 1024 畅通工程 -- 并查集、贪心算法(最小生成树)

    题目地址:http://ac.jobdu.com/problem.php?pid=1024 题目描述:     省政府"畅通工程"的目标是使全省任何两个村庄间都可以实现公路交通(但 ...

  8. 九度OJ 1371 最小的K个数 -- 堆排序

    题目地址:http://ac.jobdu.com/problem.php?pid=1371 题目描述: 输入n个整数,找出其中最小的K个数.例如输入4,5,1,6,2,7,3,8这8个数字,则最小的4 ...

  9. 九度OJ 题目1384:二维数组中的查找

    /********************************* * 日期:2013-10-11 * 作者:SJF0115 * 题号: 九度OJ 题目1384:二维数组中的查找 * 来源:http ...

随机推荐

  1. js 值类型和引用类型

    function chainStore() { var store1='Nike China'; var store2=store1; store1='Nike U.S.A.'; alert(stor ...

  2. centos7下使用wget命令安装mysql

    1.首先安装wget命令: yum -y install  wget 2.下载mysql wget http://repo.mysql.com/mysql-community-release-el7- ...

  3. java.lang.NoSuchMethodError: main Exception in thread "main" ===Exception

    java.lang.NoSuchMethodError: mainException in thread "main" 出现该异常是因为在之前我的项目中自定义了一个String类, ...

  4. 安全搜索引擎Shodan(搜蛋)命令行模式使用TIPS

    https://www.shodan.io/ 与谷歌通过网址来搜索互联网的方式不同,Shodan通过互联网背后的通道来搜索信息.它就象是一种“黑暗”的谷歌,不断在寻找服务器.网络摄像头.打印机.路由器 ...

  5. php 报错等级

    定义和用法:    error_reporting() 设置 PHP 的报错级别并返回当前级别. 函数语法:    error_reporting(report_level) 如果参数 level 未 ...

  6. Spark原理小总结

    1.spark是什么? 快速,通用,可扩展的分布式计算引擎 2.弹性分布式数据集RDD RDD(Resilient Distributed Dataset)叫做分布式数据集,是Spark中最基本的数据 ...

  7. Linux中ping不通外网

    在linux中ping www.baidu.com 无法ping通 需要修改vi /etc/resolv.conf 增加如下内容: nameserver 114.114.114.114 nameser ...

  8. zabbix学习系列之触发器

    触发器的简介 监控项仅负责收集数据,而通常收集数据的目的还包括在某指标对应的数据超出合理范围时给相关人员发送告警信息,"触发器"正式 用于为监控项所收集的数据定义阈值 每一个触发器 ...

  9. Flak快速上手

    本文介绍如何上手 Flask . 这里假定你已经安装好了 Flask ,否则请先阅读< 安装>. 如果已安装好Flask,通过以下命令查看 一个简单的例子: from flask impo ...

  10. Performing User-Managed Database-18.7、Performing Complete User-Managed Media Recovery

    18.7.Performing Complete User-Managed Media Recovery 完毕一致性备份,把数据库恢复到当前的scn是最好的结果.能够恢复整个数据库.恢复单个表空间.或 ...