hei
Miten saan float-tyyppisen arvon määriteltyä siten,että se tulostuu 4 desimaalin tarkuudella ja pyöristetään oikein. Desimaalien tarkkuuden osaan, mut toi pyöristys.
float
4
1054
Vastaukset
- pyöriäinen
Eikö toi pyöristä oikein (mulla ainakin):
C:
printf("%.4f\n", fluku);
C :
std::cout - c-burnout
Tein pienen testin ja pyöristys ei tosiaan toiminut kunnolla (Visual Studio 6 kirjastot ja kääntäjä).
printf("\n%f, %0.4f", (float)0.0000400, (float)0.0000400);
printf("\n%f, %0.4f", (float)0.0000500, (float)0.0000500);
printf("\n%f, %0.4f", (float)0.0000501, (float)0.0000501);
printf("\n%f, %0.4f", (float)0.0000600, (float)0.0000600);
Ja tulos oli:
0.0000400, 0.0000
0.0000500, 0.0000
0.0000501, 0.0001
0.0000600, 0.0001
Elikkä tuo 0.0000500 ei pyöristynyt oikein ylöspäin. Outoa tosiaan?
Toisaalta voit lisätä kaikkiin lukuihin tuon 0.000001 arvon jolloin pyöristys taas toimii.
#define FIXFLOAT( x ) ((float)x 0.0000001)
printf("%.4f", FIXFLOAT(0.00005));
antaa nyt oikean vastauksen 0.0001- menee pieleen
negatiiviset, huomasitko?
- TRRY
Pyöristys meni ihan oikein. Syy ongelmaasi on tässä:
printf("\n%0.12f", (float)0.0000500);
Eli annoit pyöristettäväksi luvun, joka on itse asiassa hieman pienempi kuin 0,00005. Floateilla ei pysty esittämään lukua 0,00005 eikä montaa muutakaan lukua tarkasti. Doublen käyttäminenkään ei ratkaise ongelmaa. Jos tarvitset tarkkoja tuloksia, laske kokonaisluvuilla.
Ketjusta on poistettu 0 sääntöjenvastaista viestiä.
Luetuimmat keskustelut
- 1077763
Siekkilässä ajettu ihmisten yli- mitä tapahtui? Länsi-Savo ei ole uutisoinut asiata
Manneja, vaiko matuja?1126026- 835177
- 1394546
Alavuden sairaala
Säästääkö Alavuden sairaala sähkössä. Kävin Sunnuntaina vast. otolla. Odotushuone ja käytävä jolla lääkäri otti vastaan113220- 592997
- 582938
Törkeää toimintaa
Todella törkeitä kaheleita niitä on Ylivieskassakin. https://www.ess.fi/uutissuomalainen/8570818102454- 612437
Hei........
Pelkkä sun näkeminen saa mut hymyilemään pitkin iltaa. Oot niin 🤩😘 Edellinen poistettiin.562066