• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Dziwna wartość liczby typu double w c++

Object Storage Arubacloud
0 głosów
167 wizyt
pytanie zadane 6 września 2020 w C i C++ przez Arek04 Użytkownik (700 p.)
Pisząc program w cpp najechałem kursorem na liczbę typu double i pokazało się dziwne rozwinięcie tej liczby. Dlaczego tak się dzieje skoro teoretycznie do końca powinny być same zera ? Dla 2.9 np. jest 2.899999999911.

Link do zdj: https://iv.pl/images/3c22c566c4d82eb60e8c5fad0cf15df4.png

1 odpowiedź

+2 głosów
odpowiedź 6 września 2020 przez Michałełe Nałogowiec (25,600 p.)

Jest to spowodowane kodowaniem liczb zmiennoprzecinkowych. W C++ typy zmiennoprzecinkowe mamy 3:

float - single precision

double - double precision

long double - extended precision (musi mieć przynajmniej double precision, ale może mieć więcej)

komentarz 6 września 2020 przez Oscar Nałogowiec (29,320 p.)
Dokładnie jest to spowodowane tym, że wartość "jedna dziesiąta" nie ma skończonego rozwinięcia w układzie dwójkowym. Więc "równe" liczby ułamkowe w układzie dziesiątkowym, w układzie dwójkowym nie mogą być dokładnie reprezentowane na skończonej liczbie bitów.

10=2*5, w układzie dwójkowym brakuje tej piątki.

Podobne pytania

0 głosów
2 odpowiedzi 732 wizyt
+2 głosów
1 odpowiedź 1,287 wizyt
pytanie zadane 1 listopada 2016 w C i C++ przez Arturo332 Początkujący (250 p.)
0 głosów
2 odpowiedzi 1,454 wizyt
pytanie zadane 15 maja 2018 w C i C++ przez Marte Nowicjusz (140 p.)

92,573 zapytań

141,423 odpowiedzi

319,648 komentarzy

61,959 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...