ref: 600bbfe4aaa9ad0f73d8d73eef1b7670e5f7d3a3
dir: /libmp/port/mpmod.c/
#include "os.h" #include <mp.h> #include "dat.h" // remainder = b mod m // // knuth, vol 2, pp 398-400 void mpmod(mpint *b, mpint *m, mpint *remainder) { mpdiv(b, m, nil, remainder); if(remainder->sign < 0) mpadd(m, remainder, remainder); }