См. Код ниже. Мне трудно найти решение, при котором среднее значение двух чисел длинная в java не приводит к переполнению. Проблема в том, что я добавляю нечетное целое число с четным отрицательным целым числом, например 11 и -12 приводит к среднему значению 1 для меня, используя ниже. Есть ли реальный способ сделать это без использования математической программы и с использованием только примитивного программирования?
if (maximum > minimum) {
this.max = maximum; this.min = minimum;
this.counter = (minimum & maximum) + ((minimum ^ maximum) >> 1);
}
else if (minimum > maximum) {
this.min = maximum; this.max = minimum;
this.counter = (maximum & minimum) + ((maximum ^ minimum) >> 1);
}
else {
this.max = maximum; this.min = minimum; counter = this.max;
}
Вы можете сохранить остаток от обоих значений для целочисленного деления на 2, затем выполнить это деление, сложить результаты и, наконец, использовать остатки для корректировки значения, если это необходимо.
Ни одно из этих решений не округляет в направлении нуля, если оба целых числа отрицательны. Какие-нибудь предложения по этому поводу, пожалуйста?
В случае, если одно положительное, а другое - отрицательное, можно не беспокоиться о переполнении. Вы можете просто просуммировать их и разделить на 2.