第5章减治法剖析.pptVIP

  • 32
  • 0
  • 约7.61千字
  • 约 43页
  • 2017-03-21 发布于湖北
  • 举报
具有11个结点的判定树 问题的解决是经过一系列比较和判断,可以用判定树来描述这个判定过程。 解决这个问题的最自然的想法就是一分为二,也就是把硬币分成两组。把n枚硬币分成两组,每组有 枚硬币,如果n为奇数,就留下一枚硬币,然后把两组硬币分别放到天平的两端。如果两组硬币的重量相同,那么留下的硬币就是假币;否则,用同样的方法对较轻的那组硬币进行同样的处理,假币一定在较轻的那组里。 考虑不是把硬币分成两组,而是分成三组,前两组有 组硬币,其余的硬币作为第三组,将前两组硬币放到天平上,如果他们的重量相同,则假币一定在第三组中,用同样的方法对第三组进行处理;如果前两组的重量不同,则假币一定在较轻的那一组中,用同样的方法对较轻的那组硬币进行处理。显然这个算法存在递推式: 算法5.8——淘汰赛冠军问题 string Game(string r[ ], int n) { i=n; while (i1) { i=i/2; for (j=0; ji; j++) if (Comp(r[j+i], r[j])) r[j]=r[j+i]; }

文档评论(0)

1亿VIP精品文档

相关文档