⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 rand_r.c

📁 KPIT GNU Tools is a set of GNU development tools for Renesas microcontrollers.
💻 C
字号:
#include <stdlib.h>/* Pseudo-random generator based on Minimal Standard by   Lewis, Goodman, and Miller in 1969.    I[j+1] = a*I[j] (mod m)   where a = 16807         m = 2147483647   Using Schrage's algorithm, a*I[j] (mod m) can be rewritten as:       a*(I[j] mod q) - r*{I[j]/q}      if >= 0     a*(I[j] mod q) - r*{I[j]/q} + m  otherwise   where: {} denotes integer division           q = {m/a} = 127773           r = m (mod a) = 2836   note that the seed value of 0 cannot be used in the calculation as   it results in 0 itself*/      int_DEFUN (rand_r, (seed), unsigned int *seed){        long k;        long s = (long)(*seed);        if (s == 0)          s = 0x12345987;        k = s / 127773;        s = 16807 * (s - k * 127773) - 2836 * k;        if (s < 0)          s += 2147483647;        (*seed) = (unsigned int)s;        return (int)(s & RAND_MAX);}

⌨️ 快捷键说明

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