Bir modül negatif olabilir mi?
%
Euclidean_division'dan sonra değil , kalan operatör , bölünme sonrası kalan kısım olduğu için negatif olabilir . C99'dan beri sonuç 0, negatif veya pozitif olabilir.
// a % b
7 % 3 --> 1
7 % -3 --> 1
-7 % 3 --> -1
-7 % -3 --> -1
İstenen modulo OP klasik bir Öklid modülo değil %
.
Her seferinde olumlu bir sonuç bekliyordum.
Ne zaman iyi tanımlanmış bir Öklid modulo gerçekleştirmek için a/b
tanımlanır, a,b
herhangi bir işaretin olması ve sonucu negatif asla:
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