The Wayback Machine - https://web.archive.org/web/20180428234203/http://ja.cppreference.com:80/w/cpp/algorithm/min
名前空間
変種
操作

std::min

提供: cppreference.com
< cpp‎ | algorithm

 
 
アルゴリズムライブラリ
実行ポリシー (C++17)
非変更シーケンス操作
(C++11)(C++11)(C++11)
(C++17)
変更シーケンス操作
未初期化記憶域の操作
分割操作
ソート操作
バイナリサーチ操作
集合操作 (ソート済み範囲に対する)
ヒープ操作
(C++11)
最小/最大演算
(C++11)
(C++17)
順列
数値演算
C のライブラリ
 
ヘッダ <algorithm> で定義
template<class T >
const T& min(const T& a, const T& b );
(1)
template<class T, class Compare >
const T& min(const T& a, const T& b, Compare comp );
(2)
template<class T >
T min(std::initializer_list<T> ilist);
(3) (C++11およびそれ以降)
template<class T, class Compare >
T min(std::initializer_list<T> ilist, Compare comp );
(4) (C++11およびそれ以降)
1-2)
2つの値のうち小さい方を返します。.
Original:
Returns the smaller of the two values.
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
3-4)
初期化子リストilist内の値の最小値を返します。.
Original:
Returns the smallest of the values in initializer list ilist.
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
(1,3)のバージョンでは値を比較するoperator<使用、(2,4)のバージョンは、指定された比較関数compを使用.
Original:
The (1,3) versions use operator< to compare the values, the (2,4) versions use the given comparison function comp.
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.

目次

[編集]パラメータ

a, b -
比較する値
Original:
the values to compare
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
ilist -
比較するための値で初期化子リスト
Original:
initializer list with the values to compare
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
cmp - 比較関数. if a is less than b 場合、 ​trueを返します.

比較関数のシグネチャは以下と同等でなければなりません.

 bool cmp(const Type1 &a, const Type2 &b);

シグネチャはconstを含まなくても構いませんが, 比較関数は渡されたオブジェクトを変更してはなりません.
Type1 および Type2 は、どちらも T 型のオブジェクトから暗黙に変換可能なものでなければなりません。 ​

型の要件
-
TLessThanComparable の要件を満たさなければなりません。 for the overloads (1) and (3)
-
TCopyConstructible の要件を満たさなければなりません。 for the overloads (3) and (4)

[編集]値を返します

1-2)
aの小さい方とb。値が等しい場合、返品a.
Original:
The smaller of a and b. If the values are equivalent, returns a.
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
3-4)
ilistの最小値。いくつかの値が最小と同等である場合は、一番左のような値を返します。.
Original:
The smallest value in ilist. If several values are equivalent to the smallest, returns the leftmost such value.
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.

[編集]複雑性

1-2) 定数

3-4)
ilist.size()のリニア
Original:
Linear in ilist.size()
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.

[編集]可能な実装

1つめのバージョン
template<class T>const T& min(const T& a, const T& b){return(a < b)? a : b;}
2つめのバージョン
template<class T, class Compare>const T& min(const T& a, const T& b, Compare comp){return(comp(a, b))? a : b;}
3つめのバージョン
template<class T> T min(std::initializer_list<T> ilist){return*std::min_element(ilist.begin(), ilist.end());}
4つめのバージョン
template<class T, class Compare> T min(std::initializer_list<T> ilist, Compare comp){return*std::min_element(ilist.begin(), ilist.end(), comp);}

[編集]

#include <algorithm>#include <iostream>   int main(){std::cout<<"smaller of 1 and 9999: "<< std::min(1, 9999)<<'\n';std::cout<<"smaller of 'a' and 'b': "<< std::min('a', 'b')<<'\n';std::cout<<"smaller of 3.5 and 2.5: "<< std::min(3.5, 2.5)<<'\n';}

出力:

smaller of 1 and 9999: 1 smaller of 'a' and 'b': a smaller of 3.5 and 2.5: 2.5

[編集]参照

指定された値の大きい方を返します
(関数テンプレート)[edit]
(C++11)
2つの要素の小さい方と大きい方を返します
(関数テンプレート)[edit]
指定範囲の最も小さな要素を返します
(関数テンプレート)[edit]
close