Чи може модуль бути негативним?
%
може бути негативним, оскільки це оператор , що залишився, решта після поділу, а не після Евклідового_розділу . Оскільки С99 результат може бути 0, негативним чи позитивним.
// a % b
7 % 3 --> 1
7 % -3 --> 1
-7 % 3 --> -1
-7 % -3 --> -1
За модулю OP хотів класичний евклідової по модулю , що не %
.
Я щоразу очікував позитивного результату.
Виконання евклідового модуля, який є чітко визначеним щоразу, коли a/b
визначено, a,b
є будь-якими ознаками, і результат ніколи не буде негативним:
int modulo_Euclidean(int a, int b) {
int m = a % b;
if (m < 0) {
// m += (b < 0) ? -b : b; // avoid this form: it is UB when b == INT_MIN
m = (b < 0) ? m - b : m + b;
}
return m;
}
modulo_Euclidean( 7, 3) --> 1
modulo_Euclidean( 7, -3) --> 1
modulo_Euclidean(-7, 3) --> 2
modulo_Euclidean(-7, -3) --> 2