mirror of https://github.com/0intro/conterm
16 lines
247 B
C
16 lines
247 B
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);
|
||
|
}
|