Matching Nuts and Bolts 螺母螺帽的匹配

来源:互联网 发布:杭州 数据分析 编辑:程序博客网 时间:2024/04/28 15:55

问题:给你一堆螺母和螺帽,每个螺母都有一个相对应的螺帽,但是他们之间的对应关系已经打乱。你可以比较螺母和螺帽的大小关系,但是你无法比较螺母和螺母的大小关系,你也无法比较螺帽和螺帽的大小关系。设计一个算法,找出螺母和螺帽的对应关系。

思路:一个简单的方法就是,对每一个螺母,用线性搜索的方法找出对应的螺帽,复杂度是O(n^2)。

下面给出一个类似于快速排序的算法,平均复杂度是O(n Log(n) )。

  1. 拿一个螺母。
  2. 把剩下的螺帽分成两堆,一堆比第一步的螺母小,一堆比第一步的螺母大。
  3. 找出与第一步中的螺母相匹配的螺帽。
  4. 用第三步中的螺帽把剩下的螺母分成两堆。

上面的算法的平均复杂度是 O(n Log(n) ),最坏复杂度是O(n^2).

0 0