[解決済み] floatの最大値/最小値を初期化するには?
2022-09-27 18:01:55
質問
floatやdoubleの絶対的な最大値や最小値をハードコードするにはどうしたらよいでしょうか。私は、単純に反復して最大のものをキャッチすることによって、配列の最大/最小値を検索したいです。
浮動小数点数の正と負の無限大もありますが、代わりにそれを使うべきですか?もしそうなら、私のコードでそれをどのように表記すればよいですか?
どのように解決するのですか?
あなたは
std::numeric_limits
で定義されている
<limits>
を使って、型の最小値や最大値を求めることができます(その型に特化したものが存在する限り)。また、無限大を検索するために使うこともできます(そして、そのために
-
を前に置く)。
#include <limits>
//...
std::numeric_limits<float>::max();
std::numeric_limits<float>::min();
std::numeric_limits<float>::infinity();
コメントで指摘されているように
min()
は可能な限り低い正の値を返します。言い換えれば、表現可能な 0 に最も近い正の値です。可能な限り低い値は、可能な限り大きい値の負の値です。
もちろん
std::max_element
と min_element 関数 (
<algorithm>
) の方が、配列の中で最大または最小の値を見つけるには良い選択かもしれません。
関連
-
[解決済み】C++エラー。アーキテクチャ x86_64 に対して未定義のシンボル
-
[解決済み】クラステンプレートの引数リストがない
-
[解決済み] error: 'ostream' does not name a type.
-
[解決済み】変数 '' を抽象型 '' と宣言できない。
-
[解決済み】C++プログラムでのコンソールの一時停止
-
[解決済み】エラー。switchステートメントでcaseラベルにジャンプする
-
[解決済み】#include<iostream>は存在するのですが、「識別子 "cout "は未定義です」というエラーが出ます。なぜですか?
-
[解決済み】ファイルから整数を読み込んで配列に格納する C++ 【クローズド
-
[解決済み】C++ - ステートメントがオーバーロードされた関数のアドレスを解決できない。
-
[解決済み] C++で静的プライベートメンバを初期化する方法は?
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み] テスト
-
[解決済み】クラステンプレートの引数リストがない
-
[解決済み】識別子 "string "は未定義?
-
[解決済み】C++ - 解放されるポインタが割り当てられていないエラー
-
[解決済み】エラー:strcpyがこのスコープで宣言されていない
-
[解決済み】C++プログラムでのコンソールの一時停止
-
[解決済み】Visual Studio 2013および2015でC++コンパイラーエラーC2280「削除された関数を参照しようとした」が発生する
-
[解決済み】オブジェクト引数のない非静的メンバ関数の呼び出し コンパイラーエラー
-
[解決済み】Visual Studioのデバッガーエラー。プログラムを開始できません 指定されたファイルが見つかりません
-
[解決済み] 変数サイズのオブジェクトが初期化されないことがある c++