Um módulo pode ser negativo?
%
pode ser negativo, pois é o operador restante , o restante após a divisão, não após a divisão Euclidean . Desde C99, o resultado pode ser 0, negativo ou positivo.
// a % b
7 % 3 --> 1
7 % -3 --> 1
-7 % 3 --> -1
-7 % -3 --> -1
O módulo OP desejado é um módulo euclidiano clássico , não %
.
Eu estava sempre esperando um resultado positivo.
Executar um módulo euclidiano que seja bem definido sempre que a/b
for definido a,b
é de qualquer sinal e o resultado nunca é negativo:
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