Matching Nuts and Bolts 螺母螺帽的匹配

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

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

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

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

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值