genprime.c

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

C
28
字号
#include "os.h"#include <mp.h>#include <libsec.h>//  generate a probable prime.  accuracy is the miller-rabin interationsvoidgenprime(mpint *p, int n, int accuracy){	mpdigit x;	// generate n random bits with high and low bits set	mpbits(p, n);	genrandom((uchar*)p->p, (n+7)/8);	p->top = (n+Dbits-1)/Dbits;	x = 1;	x <<= ((n-1)%Dbits);	p->p[p->top-1] &= (x-1);	p->p[p->top-1] |= x;	p->p[0] |= 1;	// keep icrementing till it looks prime	for(;;){		if(probably_prime(p, accuracy))			break;		mpadd(p, mptwo, p);	}}

⌨️ 快捷键说明

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