mpinvert.c

来自「这是一个同样来自贝尔实验室的和UNIX有着渊源的操作系统, 其简洁的设计和实现易」· C语言 代码 · 共 22 行

C
22
字号
#include "os.h"#include <mp.h>#define iseven(a)	(((a)->p[0] & 1) == 0)// use extended gcd to find the multiplicative inverse// res = b**-1 mod mvoidmpinvert(mpint *b, mpint *m, mpint *res){	mpint *dc1, *dc2;	// don't care	dc1 = mpnew(0);	dc2 = mpnew(0);	mpextendedgcd(b, m, dc1, res, dc2);	if(mpcmp(dc1, mpone) != 0)		abort();	mpmod(res, m, res);	mpfree(dc1);	mpfree(dc2);}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?