Arbitrary-Precision Dezimalzahlen in C # [Duplikat]
Frage
Mögliche Duplikate:
Big ganzen Zahlen in C #
C # unlimited signifikante Dezimalstellen (beliebige Genauigkeit) ohne java
las ich die Frage an beliebiger Genauigkeit Dezimalstellen in C #? aber ich don‘ t haben die # -Bibliothek J. Ich brauche eine Bibliothek für beliebig genaue Dezimalstellen mit C #.
Lösung
Big Dezimal:
- Installieren Sie die J # Runtime (es ist kostenlos): http://www.microsoft.com/downloads/en/details.aspx?familyid=f72c74b3-ed0e-4af8-ae63-2f0e42501be1&displaylang=en
Big Int (Wenn Sie wie J. D.-Lösung oder wollen mit einer rationalen Zahl / Fraktion Typklasse kommen, und ich irgendwie verpasst, dass Sie für Dezimalzahlen suchen, nicht ints.):
- Get C # 4.0: Big ganze Zahlen in C #
- Holen Sie sich das IntX Klasse: http://intx.codeplex.com/
Andere Tipps
könnten Sie Ihre eigene Implementierung auf Basis von .NET 4.0 der BigInteger-Klasse. Ich tue dies für Spaß, es tut Multiplikation nur:
public struct BigDecimal {
public BigInteger Integer { get; set; }
public BigInteger Scale { get; set; }
public BigDecimal(BigInteger integer, BigInteger scale) : this() {
Integer = integer;
Scale = scale;
while (Scale > 0 && Integer % 10 == 0) {
Integer /= 10;
Scale -= 1;
}
}
public static implicit operator BigDecimal(decimal a) {
BigInteger integer = (BigInteger)a;
BigInteger scale = 0;
decimal scaleFactor = 1m;
while ((decimal)integer != a * scaleFactor) {
scale += 1;
scaleFactor *= 10;
integer = (BigInteger)(a * scaleFactor);
}
return new BigDecimal(integer, scale);
}
public static BigDecimal operator *(BigDecimal a, BigDecimal b) {
return new BigDecimal(a.Integer * b.Integer, a.Scale + b.Scale);
}
public override string ToString() {
string s = Integer.ToString();
if (Scale != 0) {
if (Scale > Int32.MaxValue) return "[Undisplayable]";
int decimalPos = s.Length - (int)Scale;
s = s.Insert(decimalPos, decimalPos == 0 ? "0." : ".");
}
return s;
}
}
...
decimal d1 = 254727458263237.1356246819m;
decimal d2 = 991658834219519273.110324m;
// MessageBox.Show((d1 * d2).ToString()); // OverflowException
BigDecimal bd1 = d1;
BigDecimal bd2 = d2;
MessageBox.Show((bd1 * bd2).ToString()); // 252602734305022989458258125319270.5452949161059356
Es gibt immer die GNU MP-Wrapper für .NET , solange Sie nicht das eine mit nichts dagegen < href = "http://gmplib.org/" rel = "nofollow"> GMP .