【译】Swift算法俱乐部-查找最大/最小值

栏目: Swift · 发布时间: 6年前

内容简介:我们有一个通用对象数组,我们迭代所有对象,跟踪遇到的最小/最大元素。假设我们想在未排序列表选择第一个数字

我们有一个通用对象数组,我们迭代所有对象,跟踪遇到的最小/最大元素。

例子

假设我们想在未 排序 列表 [8,3,9,4,6] 中找到最大值。

选择第一个数字 8 ,并将其存储作为目前为止的最大元素。

从列表中选择下一个数字 3 ,并将其与当前最大值进行比较。 3 小于 8 所以最大值 8 不会改变。

从列表中选择下一个数字 9 ,并将其与当前最大值进行比较。 9 大于 8 所以我们存储 9 作为最大值。

重复此过程,直到处理完列表中的所有元素。

代码

在Swift中的一个简单实现:

func minimum<T: Comparable>(_ array: [T]) -> T? {
  guard var minimum = array.first else {
    return nil
  }

  for element in array.dropFirst() {
    minimum = element < minimum ? element : minimum
  }
  return minimum
}

func maximum<T: Comparable>(_ array: [T]) -> T? {
  guard var maximum = array.first else {
    return nil
  }

  for element in array.dropFirst() {
    maximum = element > maximum ? element : maximum
  }
  return maximum
}
复制代码

将代码放在 playground 测试:

let array = [ 8, 3, 9, 4, 6 ]
minimum(array)   // This will return 3
maximum(array)   // This will return 9
复制代码

Swift的标准库

Swift库已经包含一个叫做 SequenceType 的扩展,它可返回序列中的最小/最大元素。

let array = [ 8, 3, 9, 4, 6 ]
array.minElement()   // This will return 3
array.maxElement()   // This will return 9
复制代码
let array = [ 8, 3, 9, 4, 6 ]
//swift3
array.min()   // This will return 3
array.max()   // This will return 9
复制代码

最大值和最小值

要同时查找数组中包含的最大值和最小值,为了最小化比较次数,我们可以成对比较。

例子

假设我们想要在未排序列表 [8,3,9,6,4] 中找到最小值和最大值。

选择第一个数字 8 ,并将其存储为目前为止的最小和最大值。

因为我们有一个奇数项目,我们从列表中删除 8 ,留下两队 [3,9][6,4]

从列表中选择下一对数字, [3,9] 。 在这两个数字中, 3 是较小的数字,因此我们将 3 与当前最小值 8 进行比较,并将 9 与当前最大值 8 进行比较。 3 小于 8 ,所以新的最小值是 39 大于 8 ,所以新的最大值是 9

从列表中选择下一对数字, [6,4] 。 这里, 4 是较小的一个,所以我们将 4 与当前最小 3 进行比较,并将 6 与当前最大 9 进行比较。 4 大于 3 ,所以最小值不会改变。 6 小于 9 ,因此最大值不会改变。

结果是最小值为 3 ,最大值为 9

代码

在Swift中的一个简单实现:

func minimumMaximum<T: Comparable>(_ array: [T]) -> (minimum: T, maximum: T)? {
  guard var minimum = array.first else {
    return nil
  }
  var maximum = minimum

  // if 'array' has an odd number of items, let 'minimum' or 'maximum' deal with the leftover
  let start = array.count % 2 // 1 if odd, skipping the first element
  for i in stride(from: start, to: array.count, by: 2) {
    let pair = (array[i], array[i+1])

    if pair.0 > pair.1 {
      if pair.0 > maximum {
        maximum = pair.0
      }
      if pair.1 < minimum {
        minimum = pair.1
      }
    } else {
      if pair.1 > maximum {
        maximum = pair.1
      }
      if pair.0 < minimum {
        minimum = pair.0
      }
    }
  }

  return (minimum, maximum)
}
复制代码

在playground测试:

let result = minimumMaximum(array)!
result.minimum   // This will return 3
result.maximum   // This will return 9
复制代码

通过成对挑选元素并将其最大值和最小值与当前的最小值和最大值进行比较,我们将每2个元素的比较次数减少到3次。


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

十亿美金的教训

十亿美金的教训

林军 唐宏梅 / 浙江大学出版社 / 2011-5 / 39.00元

《十亿美金的教训》内容简介:创业者个人能力欠缺、团队涣散、经营方向把握不当、资金动用失措以及时局不利……这其中有哪一个细节被忽视,都可能是失败的导火索! 国内二十年互联网风云,有人成功,有人失败。两种结果,不同方向,却往往只是一线之隔。他们留给我们怎样的教训与启示?后来者要怎样才能跳出失败之殇? 《十亿美金的教训》选取了互联网十个经典的失败案例,并深层解读这些互联网企业与创业者们从成功......一起来看看 《十亿美金的教训》 这本书的介绍吧!

SHA 加密
SHA 加密

SHA 加密工具

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具