@ solusion de recursiva (La respuesta aceptada) es 100% correcto. Solo estoy agregando un código de muestra para su referencia.
Mi caso es para mostrar el precio con dos dígitos decimales.Esto es parte de la respuesta de back-end: "price": 2300, "currencySymbol": "CD", ...
.
Esta es mi clase de ayuda:
public class CurrencyUtils
{
private static final String[] suffix = { "", "K", "M" };
public static String getCompactStringForDisplay(final int amount)
{
int suffixIndex;
if (amount >= 1_000_000) {
suffixIndex = 2;
} else if (amount >= 1_000) {
suffixIndex = 1;
} else {
suffixIndex = 0;
}
int quotient;
int remainder;
if (amount >= 1_000_000) {
quotient = amount/1_000_000;
remainder = amount % 1_000_000;
} else if (amount >= 1_000) {
quotient = amount/1_000;
remainder = amount % 1_000;
} else {
return String.valueOf(amount);
}
if (remainder == 0) {
return String.valueOf(quotient) + suffix[suffixIndex];
}
// Keep two most significant digits
if (remainder >= 10_000) {
remainder /= 10_000;
} else if (remainder >= 1_000) {
remainder /= 1_000;
} else if (remainder >= 100) {
remainder /= 10;
}
return String.valueOf(quotient) + '.' + String.valueOf(remainder) + suffix[suffixIndex];
}
}
Ésta es mi clase de prueba (basado en Junit 4):
public class CurrencyUtilsTest {
@Test
public void getCompactStringForDisplay() throws Exception {
int[] numbers = {0, 5, 999, 1_000, 5_821, 10_500, 101_800, 2_000_000, 7_800_000, 92_150_000, 123_200_000, 9_999_999};
String[] expected = {"0", "5", "999", "1K", "5.82K", "10.50K", "101.80K", "2M", "7.80M", "92.15M", "123.20M", "9.99M"};
for (int i = 0; i < numbers.length; i++) {
int n = numbers[i];
String formatted = CurrencyUtils.getCompactStringForDisplay(n);
System.out.println(n + " => " + formatted);
assertEquals(expected[i], formatted);
}
}
}
en Java no va a funcionar, si lo hace un 1,0% 0,1 – endless
@endless: Es cierto, primero tendrías que convertir a un entero. Y también tendría que especificar lo que quiere decir con el resto de dos flotantes, ya que generalmente se define en términos de aritmética de enteros. – recursive
Solo si alguien repasa esta pregunta y se pregunta cómo obtendría el cociente, pero el número natural más grande <= el cociente o el mod puede usar la función en el paquete matemático: 'Math.floorDiv (x, y)' y 'Math.floorMod (x, y)' –