Game Design
數學、物理、圖形學、匯編/C/C++數據結構與算法、windows程序設計
C++博客
首頁
新隨筆
聯系
聚合
管理
隨筆-11 評論-20 文章-0 trackbacks-0
生成隨機數的一個工具類
1
#include
<
iostream
>
2
#include
<
time.h
>
3
4
using
namespace
std;
5
6
//
generate random numbers
7
class
randomNumber
8
{
9
public
:
10
//
initialize the random number generator
11
randomNumber(
long
s
=
0
);
12
13
//
return a 32-bit random integer m, 1 <= m <= 2^31-2
14
long
random();
15
16
//
return a 32-bit random integer m, 0 <= m <= n-1,
17
//
where n <= 2^31-1
18
long
random(
long
n);
19
20
//
return a real number x, 0 <= x < 1
21
double
frandom();
22
23
private
:
24
static
const
long
A;
25
static
const
long
M;
26
static
const
long
Q;
27
static
const
long
R;
28
29
long
seed;
30
}
;
31
32
const
long
randomNumber::A
=
48271
;
33
const
long
randomNumber::M
=
2147483647
;
34
const
long
randomNumber::Q
=
M
/
A;
35
const
long
randomNumber::R
=
M
%
A;
36
37
randomNumber::randomNumber(
long
s)
38
{
39
if
(s
<
0
)
40
s
=
0
;
41
42
if
(s
==
0
)
43
{
44
//
get time of day in seconds since 12:00 AM,
45
//
January 1, 1970
46
long
t_time
=
time(NULL);
47
48
//
mix-up bits by squaring
49
t_time
*=
t_time;
50
//
result can overflow. handle cases
51
//
> 0, < 0, = 0
52
if
(t_time
>
0
)
53
s
=
t_time
^
0x5EECE66DL
;
54
else
if
(t_time
<
0
)
55
s
=
(t_time
&
0x7fffffff
)
^
0x5EECE66DL
;
56
else
57
s
=
0x5EECE66DL
;
58
}
59
60
seed
=
s;
61
}
62
63
long
randomNumber::random()
64
{
65
long
tmpSeed
=
A
*
( seed
%
Q )
-
R
*
( seed
/
Q );
66
67
if
( tmpSeed
>=
0
)
68
seed
=
tmpSeed;
69
else
70
seed
=
tmpSeed
+
M;
71
72
return
seed;
73
}
74
75
long
randomNumber::random(
long
n)
76
{
77
double
fraction
=
double
(random())
/
double
(M);
78
79
return
int
(fraction
*
n);
80
}
81
82
double
randomNumber::frandom()
83
{
84
return
double
(random())
/
double
(M);
85
}
86
posted on 2009-08-24 19:35
diwayou
閱讀(1946)
評論(1)
編輯
收藏
引用
所屬分類:
數據結構與算法
評論:
#
re: 生成隨機數的一個工具類
2011-04-05 18:12 |
shilei230
能否解釋下什么原理不?這里的魔數真不少
回復
更多評論
刷新評論列表
只有注冊用戶
登錄
后才能發表評論。
【推薦】100%開源!大型工業跨平臺軟件C++源碼提供,建模,組態!
相關文章:
各種排序算法性能測試結果
簡單的測試各種排序算法的性能
一個簡單的計算程序運行時間的工具類
計算以t為根的子樹的結點個數
生成隨機數的一個工具類
網站導航:
博客園
IT新聞
BlogJava
博問
Chat2DB
管理
<
2025年5月
>
日
一
二
三
四
五
六
27
28
29
30
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
1
2
3
4
5
6
7
常用鏈接
我的隨筆
我的評論
我參與的隨筆
留言簿
給我留言
查看公開留言
查看私人留言
隨筆分類
(10)
Real-Time Rendering_3rd
windows程序設計(1)
生活(2)
數據結構與算法(5)
數學(1)
圖形學
物理
游戲(1)
隨筆檔案
(11)
2009年9月 (3)
2009年8月 (8)
相冊
宇多田光
搜索
積分與排名
積分 - 15337
排名 - 961
最新評論
1.?re: 生成隨機數的一個工具類
能否解釋下什么原理不?這里的魔數真不少
--shilei230
2.?re: 讓我們這些中國二流大學的學生也聽聽世界一流大學的計算機課程(轉)
太好了,多謝博主!
--鄧強
3.?re: 讓我們這些中國二流大學的學生也聽聽世界一流大學的計算機課程(轉)
是的師傅是大方
--羅萊家紡
4.?re: 讓我們這些中國二流大學的學生也聽聽世界一流大學的計算機課程(轉)
不錯~分享了
--樂蜂網
5.?re: 讓我們這些中國二流大學的學生也聽聽世界一流大學的計算機課程(轉)
牛
--李佳
閱讀排行榜
1.?讓我們這些中國二流大學的學生也聽聽世界一流大學的計算機課程(轉)(4579)
2.?各種排序算法性能測試結果(2154)
3.?生成隨機數的一個工具類(1946)
4.?簡單的測試各種排序算法的性能(1744)
5.?計算幻方(1484)
評論排行榜
1.?讓我們這些中國二流大學的學生也聽聽世界一流大學的計算機課程(轉)(9)
2.?簡單的測試各種排序算法的性能(4)
3.?各種排序算法性能測試結果(2)
4.?暴雪CEO解讀吸引全球千萬玩家的商業秘密(2)
5.?生成隨機數的一個工具類(1)
6.?以后不能逃課了(1)
7.?計算幻方(1)
8.?計算以t為根的子樹的結點個數(0)
9.?一個簡單的計算程序運行時間的工具類(0)
10.?erroe C2471解決辦法(0)
11.?2009年9月語言排行榜:PHP超越C++(轉自CSDN:我鐘愛的C++和python啊)(0)
Powered by:
博客園
模板提供:
滬江博客
Copyright ©2025 diwayou
亚洲国产日韩欧美综合久久
|
国产福利电影一区二区三区,免费久久久久久久精
|
一本色道久久88综合日韩精品
|
久久精品国产第一区二区
|
亚洲伊人久久成综合人影院
|
欧美日韩精品久久久免费观看
|
久久夜色精品国产噜噜噜亚洲AV
|
久久夜色精品国产亚洲
|
偷窥少妇久久久久久久久
|
嫩草伊人久久精品少妇AV
|
免费观看成人久久网免费观看
|
久久亚洲国产成人影院网站
|
久久婷婷综合中文字幕
|
色老头网站久久网
|
要久久爱在线免费观看
|
久久精品夜夜夜夜夜久久
|
亚洲国产精品无码久久
|
日韩一区二区三区视频久久
|
国产精品成人久久久久三级午夜电影
|
久久综合亚洲色HEZYO国产
|
久久精品亚洲一区二区三区浴池
|
久久精品国产亚洲5555
|
国产精品美女久久久久久2018
|
亚洲伊人久久大香线蕉综合图片
|
性做久久久久久久久
|
日韩精品久久久久久
|
色欲av伊人久久大香线蕉影院
|
久久激情亚洲精品无码?V
|
国产成人精品免费久久久久
|
99精品国产免费久久久久久下载
|
国产一区二区三精品久久久无广告
|
久久青青草原综合伊人
|
色婷婷综合久久久久中文一区二区
|
精品久久久久中文字
|
99久久精品九九亚洲精品
|
久久久久国色AV免费观看
|
亚洲一本综合久久
|
91精品国产高清久久久久久91
|
精品久久久久久无码中文野结衣
|
国产99久久久久久免费看
|
99久久国产综合精品网成人影院
|