Bozuk bir şey mi var, ne olduğunu anlayamıyorum? çıkışı ileEn küçük artışla çift nasıl değiştirilir
static String getRealBinary(double val) {
long tmp = Double.doubleToLongBits(val);
StringBuilder sb = new StringBuilder();
for (long n = 64; --n > 0; tmp >>= 1)
if ((tmp & 1) == 0)
sb.insert(0, ('0'));
else
sb.insert(0, ('1'));
sb.insert(0, '[').insert(2, "] [").insert(16, "] [").append(']');
return sb.toString();
}
public static void main(String[] argv) {
for (int j = 3; --j >= 0;) {
double d = j;
for (int i = 3; --i >= 0;) {
d += Double.MIN_VALUE;
System.out.println(d +getRealBinary(d));
}
}
}
: tamsayı türleri gibi
2.0[1] [00000000000] [000000000000000000000000000000000000000000000000000]
2.0[1] [00000000000] [000000000000000000000000000000000000000000000000000]
2.0[1] [00000000000] [000000000000000000000000000000000000000000000000000]
1.0[0] [11111111110] [000000000000000000000000000000000000000000000000000]
1.0[0] [11111111110] [000000000000000000000000000000000000000000000000000]
1.0[0] [11111111110] [000000000000000000000000000000000000000000000000000]
4.9E-324[0] [00000000000] [000000000000000000000000000000000000000000000000001]
1.0E-323[0] [00000000000] [000000000000000000000000000000000000000000000000010]
1.5E-323[0] [00000000000] [000000000000000000000000000000000000000000000000011]
Ne yapmaya çalışıyorsunuz? Sorun nedir? – Sjoerd
Sorum şu: "En küçük artışla iki katı nasıl değiştirilir", ve bu benim başarısız olduğum çabam. – Margus
neden sadece en küçük artış yapmak istiyorsanız bu bitleri düzenlemek değil, 1 ve 2 için başarısız olur, çünkü MIN_VALUE küçük (gerçekten küçük) yani 0 + gerçekten küçük = gerçekten küçük, ama 2+ gerçekten küçük ~ = 2 YÜKSELME noktası min_value, mümkün olduğu kadar uzak bırakılırken, ortada bir yerde, solu kaybeder. Farkın yapılacağı noktadan sonra yaklaşık 300 hane görebiliyorsunuz, ki bu da sadece 15-20 anlamlı basamaktan oluşan bir ikili mağaza. – flownt