问题描述:

在n枚外观相同的硬币中,有一枚是假币,并且已知假币与真币的重量不同,但不知道假币与真币相比较轻还是较重。可以通过一架天平来任意比较两组硬币,设计一个高效的算法来检测这枚假币。

解题思路:

    使用减治法的解题思路,将硬币分为3堆,则每堆的硬币数量为 n/3 ,但是这是在 n%3==0 的情况下才能成立,所以我们将 n 枚硬币分为 3 堆加 1 堆 余数堆(余数堆可能为0),则可分为如下(n-n%3)/3,  (n-n%3)/3,  (n-n%3)/3,    n%3.

如下图:

(n-n%3)/3
(n-n%3)/3
(n-n%3)/3
n%3
a
b
c
d
  1. 首先获取真币,通过从数组中随机取三枚硬币,互相比较,相等的两枚为真币,任意取一枚作为真币 记录 数组下标。
  2. 判断n中的硬币数量,如果n>2则执行3,否则执行5.
  3. 将n分为上图的四堆,拿 a 和 b 比较,如果 a == b ,则 假币在 c 或 d 中。否则假币在 a 或 b 中。
  4. 如果 a == b,则拿 a 和 c 比较。如果 a == c,则假币在d中。将 d 再次 执行本流程。如果不等,则假币在 c 中,将 d (余数堆) 再次 执行流程,并且n=n%3,。
  5. 如果 a != b,则拿 a 和 c 比较。如果 a == c,则假币在b中。将 b 再次 执行本流程。如果不等,则假币在 a 中,将 a 再次 执行流程  2,并且n=(n-n%3)/3。
  6. 如果n==2,则将两枚硬币与真的硬币(通过 数组下标 )进行比较,不同的为假币,输出结果,结束。
  7. 如果n==1,则该硬币就是假币,输出结果结束。

  *注:按照2-5流程分堆下去,在最后一执行流程 2 时,n中含有假币,并且n只可能为1或2.(初始时,n>3,若n<3,则不能判断真假)

主要代码如下:

 //计算硬币总重量
int sum_coin(int coin[],int m,int n){
int result=;
if(m>n)
return ;
for(int i=m;i<=n;i++){
result+=coin[i];
} return result;
}; //找出假币 m , n 数组下标,coin 硬币数组,relCoin 真币数组下标
int check_coin(int coin[],int m,int n,int& relCoin){ int vary=n-m+; int restCoin=vary%;
int vary2=vary-restCoin; if(vary==)
return m; if(vary==)
{
if(sum_coin(coin,m,m)==sum_coin(coin,relCoin,relCoin))
return n;
else
return m; } if(sum_coin(coin,m,m+vary2/-)==sum_coin(coin,m+vary2/,m+(vary2/)*-))//第一堆 == 第二堆
{
if( (sum_coin(coin,m,m+vary2/-)==sum_coin(coin,m+(vary2/)*,m+vary2-)))//第一堆 == 第三堆
check_coin(coin,n-restCoin+,n,relCoin);
else//第一堆 != 第三堆
check_coin(coin,m+(vary2/)*,m+vary2-,relCoin);
}
else//第一堆 != 第二堆
{
if(sum_coin(coin,m,m+vary2/-)==sum_coin(coin,m+(vary2/)*,m+vary2-))//第一堆 == 第三堆
check_coin(coin,m+vary2/,m+(vary2/)*-,relCoin);
else//第一堆 != 第三堆
check_coin(coin,m,m+vary2/-,relCoin);
} }; //返回真币数组下标
int getRelCoin(int coin[],int m,int n)
{
if(n-m+<=)
{
cout<<"硬币数小于3枚!!!无解";
return -;
}
else
{
if(coin[]==coin[])
{
return ;
}
else
{
if(coin[]==coin[])
return ;
else
{
return ;
}
}
} };
原创,转载请注明来源,默@语:www.h-five.com

n枚硬币问题(找假币)的更多相关文章

  1. Java实现8枚硬币问题(减治法)

    1 问题描述 在8枚外观相同的硬币中,有一枚是假币,并且已知假币与真币的重量不同,但不知道假币与真币相比较轻还是较重.可以通过一架天平来任意比较两组硬币,设计一个高效的算法来检测这枚假币. 2.1 减 ...

  2. xth的第 12 枚硬币(codevs 1366)

    题目描述 Description 传说 xth 曾经拥有11枚完全相同硬币(你懂得),不过今年呢,rabbit又送了他一 枚硬币.这枚硬币和其他硬币外观相同,只有重量不同,或轻或重.Xth 一不小心, ...

  3. 1366 xth 的第 12 枚硬币

    1366 xth 的第 12 枚硬币  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 钻石 Diamond 题解       题目描述 Description 传说 xth 曾 ...

  4. Ex 6_19 至多用k枚硬币兑换价格_第七次作业

    子问题定义: 定义一个二维数组b,其中b[i][j]表示用i个硬币是否能兑换价格j,表示第i个币种的面值, 递归关系: 初值设定: 求解顺序: 按下标从小到大依次求解数组b每一列的值,最后二维数组b的 ...

  5. POJ1013称硬币【枚举】

    Counterfeit Dollar Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 52474   Accepted: 16 ...

  6. 《algorithm puzzles》——谜题

    这篇文章开始正式<algorithm puzzles>一书中的解谜之旅了! 狼羊菜过河: 谜题:一个人在河边,带着一匹狼.一只羊.一颗卷心菜.他需要用船将这三样东西运至对岸,然而,这艘船空 ...

  7. c语言进阶10-算法

    一.  数据结构和算法关系 为什么要学数据结构和算法? 通常,计算机解决问题的步骤如下: 在数学模型中,计算机处理的对象之间通常存在着一种最简单的线性关系,这类数学模型就是线性的数据结构.著名计算机科 ...

  8. Java-POJ1013-Counterfeit Dollar

    在13枚硬币中找出fake的那一个 输入:三次天平称量结果 package poj.ProblemSet; import java.util.Scanner; /* 我怎么觉得是贪心算法呢? 起初对所 ...

  9. c语言进阶15-数据结构总结

    数据结构结论 1.阿基米德说过:“给我一个支点,我就能翘起地球”. 数据结构是指相互之间存在着一种或多种关系的数据元素的集合和该集合中数据元素之间的关系组成.记为:Data_Structure=(D, ...

随机推荐

  1. 【Linux_Fedora_应用系列】_1_如何安装音乐播放器和mp3解码

    因为安装环境的不同,Fedora在安装后会安装不同的软件包.通常在安装的时候有多种选择: 1.桌面环境: 适合个人日常使用,安装包含办公软件(Fedora 默认安装Open Office).娱乐影音软 ...

  2. redis事务详解

    mysql中也存在事务的概念.其实事务的定义是一样的.一组操作的集合,作为一个整体,要么全执行,要么全不执行. redis设置事务三步骤: 开始事务 :multi 操作加入事务队列 执行事务 :exe ...

  3. CI框架源码阅读笔记1 - 环境准备、基本术语和框架流程

    最开始使用CI框架的时候,就打算写一个CI源码阅读的笔记系列,可惜虎头蛇尾,一直没有行动.最近项目少,总算是有了一些时间去写一些东西.于是准备将之前的一些笔记和经验记录下来,一方面权作备忘,另一方面时 ...

  4. Python自动化测试工具Splinter简介和使用实例

    Splinter 快速介绍 官方网站:http://splinter.cobrateam.info/ 官方介绍: Splinter is an open source tool for testing ...

  5. 项目中应用eventbus解决的问题

    在项目开发过程中,往往有些功能表面看起来简单,但实际开发的结果非常复杂,仔细分析下原因发现很多都是因为附加了许多的额外功能. 真的简单吗? 比如我们对一个电商平台的商品数据做修改的功能来讲,其实非常简 ...

  6. java中newInstance()和new()

    在Java开发特别是数据库开发中,经常会用到Class.forName( )这个方法.通过查询Java Documentation我们会发现使用Class.forName( )静态方法的目的是为了动态 ...

  7. Ionic 开发环境搭建

    android sdk环境搭建并非易事,本人经过无数失败,才使用以下方式成功 配置Ionic 开发环境 1.下载JDK并配置Java运行环境 http://www.oracle.com/technet ...

  8. 移动端事件touchstart、touchmove、touchend

    关于这三个移动端的事件,详细的资料网上一搜一大片,我就不浪费时间了 1.移动端长按事件 var timer = null; $(ele).on('touchstart',function(){ tim ...

  9. swift 2.2 语法 (中)

    前言: 1.此文中的语法会根据Swift的升级变动而更新. 2.如果需要请移步 -> swift2.2 语法(上).swift 2.2语法(下) 函数 和C语言一样,swift也有函数,性质和我 ...

  10. java url方法解释

    java 的url类中有很多get方法 以下是获取值的意义 // 首先先看一下wikipedia上关于url的一个描述 //Every HTTP URL conforms to the syntax ...