减治法-假币问题减治法-假币问题.docVIP

  • 333
  • 0
  • 约1.86千字
  • 约 10页
  • 2018-04-26 发布于贵州
  • 举报
减治法-假币问题减治法-假币问题

假币问题 减治法的设计思想就是规模为n的原问题的解与较小规模(通常是n/2)的子问题的解之间具有关系: (1)原问题的解只存在于其中一个较小规模的子问题中; (2)原问题的解与其中一个较小规模的解之间存在某种对应关系。 由于原问题的解与较小规模的子问题的解之间存在这种关系,所以,只需求解其中一个较小规模的子问题就可以得到原问题的解。减治法只对一个子问题求解,并且不需要进行解的合并。应用减治法(例如减半法)得到的算法通常具有如下递推式: 所以,通常来说,应用减治法处理问题的效率是很高的,一般是O()数量级。 该算法的时间性能有这样一个递推式: 应用扩展递归技术求解这个递推式,得到T(n)=O()。 这个递推式基本上和最坏情况下折半查找的比较次数的递推式是相同的(所不同的是初始条件)。这种相似性并不令人惊讶,因为这两种算法都是基于相同的设计技术,把问题的减半。 目前为止,这些内容看上去都是很初级,实际上,该算法并不是最高效的解法。考虑不是把硬币分成两组,而是分成三组,前两组有组硬币,其余的硬币作为第三组,将前两组硬币放到天平上,如果他们的重量相同,则假币一定在第三组中,用同样的方法对第三组进行处理;如果前两组的重量不同,则假币一定在较轻的那一组中,用同样的方法对较轻的那组硬币进行处理。所以,根据我们对设计技术的分类,它是一个减治算法而且是三分法。

您可能关注的文档

文档评论(0)

1亿VIP精品文档

相关文档