Ich möchte Zahlen in eine Datei drucken, indem ich die stl mit der Anzahl der Dezimalstellen anstelle der Gesamtgenauigkeit verwende.
Also, wenn ich das mache:
int precision = 16;
std::vector<double> thePoint(3);
thePoint[0] = 86.3671436;
thePoint[1] = -334.8866574;
thePoint[2] = 24.2814;
ofstream file1(tempFileName, ios::trunc);
file1 << std::setprecision(precision)
<< thePoint[0] << "\"
<< thePoint[1] << "\"
<< thePoint[2] << "\";
Ich bekomme Zahlen wie diese:
86.36714359999999-334.886657424.28140258789063
Was ich will ist folgendes:
86.37-334.8924.28
Mit anderen Worten, an zwei Dezimalstellen abschneiden. Wenn ich die Genauigkeit auf 4 stelle, erhalte ich
86.37-334.924.28
dh die zweite Zahl wird falsch abgeschnitten.
Ich möchte nicht jede Zahl explizit manipulieren müssen, um die Kürzung zu erhalten, vor allem, weil ich scheinbar gelegentlich eine 9 wiederholt oder 0000000001 oder ähnliches zurückbleibt.
Ich bin sicher, es gibt etwas Offensichtliches, wie die Verwendung von printf(%.2f) oder etwas Ähnliches, aber ich bin mir nicht sicher, wie ich das mit stl << und ofstream mischen soll.