ntruerand.c

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

C
24
字号
#include <u.h>#include <libc.h>ulongntruerand(ulong n){	ulong m, r;	/*	 * set m to the one less than the maximum multiple of n <= 2^32,	 * so we want a random number <= m.	 */	if(n > (1UL<<31))		m = n-1;	else		/* 2^32 - 2^32%n - 1 = (2^32 - 1) - (2*(2^31%n))%n */		m = 0xFFFFFFFFUL - (2*((1UL<<31)%n))%n;	while((r = truerand()) > m)		;	return r%n;}

⌨️ 快捷键说明

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