九度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 ...
随机推荐
- Swoole MySQL 连接池的实现
目录 概述 代码 扩展 小结 概述 这是关于 Swoole 入门学习的第八篇文章:Swoole MySQL 连接池的实现. 第七篇:Swoole RPC 的实现 第六篇:Swoole 整合成一个小框架 ...
- luogu P1592 互质
题目描述 输入两个正整数n和k,求与n互质的第k个正整数. 输入输出格式 输入格式: 仅一行,为两个正整数n(≤10^6)和k(≤10^8). 输出格式: 一个正整数,表示与n互质的第k个正整数. 输 ...
- springBoot 整合 mybatis+Oracle
现在比较流行的操作数据库操作层框架Mybatis,下面我们就来看看Springboot如何整合mybatis, 之前一直在用xml形式写sql,这次依然用xml的方式感觉这种还是比较灵活方便. 添加m ...
- 鼠标悬浮弹出标题制作JQuery
今天给客户制作的网站里面加个效果,当鼠标在列表图片之外时,标题不显示,当鼠标悬浮在图片之上时,标题从底部弹出. 效果图如下: 鼠标悬浮前: 鼠标悬浮后: html代码如下: <ul class= ...
- memcache 开机启动
一. 通常:启动Memcache的服务器端的命令为:# /usr/local/bin/memcached -d -m 10 -u root -l 127.0.0.1 -p 11211 -c 256 - ...
- matlab修改文件名和删除某类文件
matlab修改多级文件夹路径下的文件名: % %%%%%%%%%%%%%%批量修改文件名一级文件夹 \路径下直接为文件 % close all;clear all;clc; % path='G:\1 ...
- 2016.12.5 在Eclipse中为实现类impl自动生成对应接口
参考来自:http://jingyan.baidu.com/article/ab69b270d63f572ca6189f51.html 在Spring应用中,常常会用到“接口+实现类”的形式,即要实现 ...
- IntelliJ IDEA 识别一个类所属的jar包package
IntelliJ IDEA 识别一个类所属的jar包package 按住ctrl,鼠标移动上去,不要点击: 有木有快捷键? ctrl+alt+B直接就过去了:需要再跳回来:
- 谈论程序中的token
-> //指针,一旦符号分开就会成以下两个意思,我们一定要注意符号 - //减号 > //大与 int a,big; if(x>big) big = x; C语言以及一些其它语言会自 ...
- Synchronous XMLHttpRequest on the main thread is deprecated because of its detrimental……
Synchronous XMLHttpRequest on the main thread is deprecated because of its detrimental effects to th ...