質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.50%
C

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

Q&A

解決済

3回答

1276閲覧

double型変数の-0.00と0.00の違い

RaitoN

総合スコア72

C

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

0グッド

0クリップ

投稿2020/07/15 01:28

double型変数の-0.00と0.00の扱いについてです.

次のコードを実行してみると出力はZEROとなりました.

C

1double x = -0.00; 2if (x < 0) puts("negative"); 3else if (x == 0) puts("ZERO"); 4else puts("positive");

なので,ifで比較するときはxはピッタシ0と同じと考えました.

double型の変数は符号部分(1bitめ?)が0か1かで符号を扱っているので,

C

1x = -0.00; 2y = 0.00;

としたときにxとyの1bitめの符号のとこだけが異なっていて,その他は同じだと思います.
なので,printfで次のように表示すると.

C

1printf("x %.2f y %.2f\n", x, y); 2//結果 x -0.00 y 0.00

と符号も込みで出力されます.

-0.00のマイナスを除いて出力したいのですがどうすればよいでしょうか?よくある

C

1x = (x < 0) ? -x : x

みたいな絶対値を返すようなコードだと-0.00のままになってしまいます.
xには色々な実数が入っているときを考えています(-0.00も含め)

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答3

0

浮動小数点数の符号を操作するものとして、以下の2つがあります。

  • copysign…ある値から別の値へ符号をコピーする(man
  • signbit…値が負の数かを(-0や負のNaNを含め)判定する(man

投稿2020/07/15 01:37

maisumakun

総合スコア145121

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

RaitoN

2020/07/15 01:47

なるほど!どちらも知らないものでした.ありがとうございます.
guest

0

fabs()を使いましょう
自分で実装したければsignbit()を使って(またはそれすら自分で実装して)判定しましょう

投稿2020/07/15 01:33

ozwk

総合スコア13512

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

RaitoN

2020/07/15 01:34

ありがとうございます.助かりました.
guest

0

ベストアンサー

fabs() で絶対値をとればよいと思います。

C言語関数辞典 - fabs, fabsf, fabsl

c

1#include <stdio.h> 2#include <math.h> 3 4int main() 5{ 6 double x = -0.00; 7 x = fabs(x); 8 printf("x %.2f\n", x); // 0.00 9}

投稿2020/07/15 01:33

編集2020/07/15 01:33
tiitoi

総合スコア21956

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

RaitoN

2020/07/15 01:34

すげえ!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.50%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問