文書   >   Foundation   >   Collections   >   Set   >   min(by:)
インスタンスメソッド
min(by:)
与えられた述語 (predicate) を要素間の比較として使用して、シーケンス内の最小の要素を返します。
宣言
パラメータ
areInIncreasingOrder | 最初の引数を 2 番目の引数の前に並べるべき場合に true を返す述語。そうでなければ、false。 |
戻り値
areInIncreasingOrder に従って、シーケンスの最小の要素。シーケンスに要素がない場合は、nil を返します。
議論
述語は、要素に対して 厳密に弱い順序付け でなければなりません。つまり、すべての要素 a、b、および c について、以下の条件が成り立たなければなりません。
- areInIncreasingOrder(a, a) は常に false です。(非再帰的)
- areInIncreasingOrder(a, b) と areInIncreasingOrder(b, c) が共に true の時、areInIncreasingOrder(a, c) もまた true です。(推移比較可能性)
- 2 つの要素は、どちらも述語 (predicate) に従って他の要素の前に順序付けされていない場合、比較不可能 です。a と b が比較不可能で、b と c が比較不可能である場合、a と c も比較不可能です。(推移比較不可能性)
この例では、辞書で min(by:) メソッドを使用して、最小値を持つキー値のペアを見つける方法を示します。
let hues = ["Heliotrope": 296, "Coral": 16, "Aquamarine": 156]
let leastHue = hues.min { a, b in a.value < b.value }
print(leastHue)
// Prints "Optional(("Coral", 16))"
複雑さ: O(n)、ここで n はシーケンスの長さです。
以下も見よ
要素の検索
subscript(Set<Element>.Index) -> Element
与えられた位置にあるメンバーにアクセスします。
func contains(where: (Element) -> Bool) -> Bool
与えられた述語 (predicate) を満たす要素がシーケンスに含まれているかどうかを示すブール値を返します。
func allSatisfy((Element) -> Bool) -> Bool
シーケンスのすべての要素が与えられた述語 (predicate) を満たすかどうかを示すブール値を返します。
func first(where: (Element) -> Bool) -> Element?
与えられた述語 (predicate) を満たすシーケンスの最初の要素を返します。
func firstIndex(of: Element) -> Set<Element>.Index?
Set 内の与えられた要素のインデックスを返すか、要素が Set のメンバーではない場合は nil を返します。
func firstIndex(where: (Element) -> Bool) -> Set<Element>.Index?
コレクションの要素が与えられた述語 (predicate) を満たす最初のインデックスを返します。
func index(of: Element) -> Set<Element>.Index?
指定された値がコレクション内で現れる最初のインデックスを返します。
Element が Equatable に準拠している場合利用可能です。
  廃止  
シーケンス内の最小の要素を返します。
Element が Comparable に準拠している場合利用可能です。
シーケンス内の最大の要素を返します。
Element が Comparable に準拠している場合利用可能です。
func max(by: (Element, Element) -> Bool) -> Element?
与えられた述語 (predicate) を要素間の比較として使用して、シーケンス内の最大の要素を返します。
トップへ
トップへ
トップへ
トップへ
トップへ