[解決済み] C++ : 暗黙の定数変換でオーバーフローが発生する [-Woverflow].
2022-02-14 12:56:29
質問
long long sum;
sum=pow(10,19);
cout<<sum;
上記のコードを C++ がエラーになります。
暗黙の定数変換でオーバーフローが発生 [-Woverflow] 。
以下のコードは正常に動作しています。
long long sum;
sum=pow(10,18);
cout<<sum;
何が問題なのでしょうか?
解決方法は?
問題は
long long
の結果を保持するには小さすぎます。
pow(10,19)
.
long long
は通常64ビットで、64ビットの整数は約1.8*10^19種類の値を保持することができます。しかし、符号付きなので、その半分しか得られない(残りの半分は負の値用)。そして、その半分は0.9*10^19で、10^19より小さいらしい。
ここでのもう一つの問題(ただし警告/オーバーフローの理由ではない)は
pow()
関数は浮動小数点値を返します。そのため、たとえ結果が
long long
- この場合、精度が落ちて正確な整数の結果が得られない可能性があります。
編集:もちろん
unsigned long long
の代わりに、このような場合です。10^19の場合はそれで十分ですが、10^20の場合はそうはいきません。ということは、この問題を、後日
unsigned long long
.
関連
-
[解決済み】C++エラー。アーキテクチャ x86_64 に対して未定義のシンボル
-
[解決済み】構造体のベクター初期化について
-
[解決済み】getline()が何らかの入力の後に使用されると動作しない 【重複あり
-
[解決済み] [Solved] Error C1083: Cannot open include file: 'stdafx.h'
-
[解決済み】致命的なエラー LNK1169: ゲームプログラミングで1つ以上の多重定義されたシンボルが発見された
-
[解決済み】IntelliSense:オブジェクトに、メンバー関数と互換性のない型修飾子がある
-
[解決済み] gdbを使用してもデバッグシンボルが見つからない
-
[解決済み】 while(cin) と while(cin >> num) の違いは何ですか?)
-
[解決済み】エラー。引数リストに一致するコンストラクタのインスタンスがない
-
[解決済み】vtableへの未定義の参照
最新
-
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 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み】LLVMで暗黙のうちに削除されたコピーコンストラクタの呼び出し
-
[解決済み】関数名の前に期待されるイニシャライザー
-
[解決済み] クラスにデフォルトコンストラクタが存在しない。
-
[解決済み】浮動小数点例外エラーが発生する: 8
-
[解決済み】「std::operator」で「operator<<」にマッチするものがない。
-
[解決済み】C++の余分な資格エラー
-
[解決済み】エラー:不完全な型へのメンバーアクセス:前方宣言の
-
[解決済み】C++ - 適切なデフォルトコンストラクタがない [重複]。
-
[解決済み] 数値定数の前にunqualified-idを付けて、数値を定義することを期待する。
-
[解決済み】デバッグアサーションに失敗しました