Game Design
數(shù)學、物理、圖形學、匯編/C/C++數(shù)據(jù)結構與算法、windows程序設計
C++博客
首頁
新隨筆
聯(lián)系
聚合
管理
隨筆-11 評論-20 文章-0 trackbacks-0
生成隨機數(shù)的一個工具類
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
閱讀(1952)
評論(1)
編輯
收藏
引用
所屬分類:
數(shù)據(jù)結構與算法
評論:
#
re: 生成隨機數(shù)的一個工具類
2011-04-05 18:12 |
shilei230
能否解釋下什么原理不?這里的魔數(shù)真不少
回復
更多評論
刷新評論列表
只有注冊用戶
登錄
后才能發(fā)表評論。
【推薦】100%開源!大型工業(yè)跨平臺軟件C++源碼提供,建模,組態(tài)!
相關文章:
各種排序算法性能測試結果
簡單的測試各種排序算法的性能
一個簡單的計算程序運行時間的工具類
計算以t為根的子樹的結點個數(shù)
生成隨機數(shù)的一個工具類
網(wǎng)站導航:
博客園
IT新聞
BlogJava
博問
Chat2DB
管理
<
2009年8月
>
日
一
二
三
四
五
六
26
27
28
29
30
31
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
常用鏈接
我的隨筆
我的評論
我參與的隨筆
留言簿
給我留言
查看公開留言
查看私人留言
隨筆分類
(10)
Real-Time Rendering_3rd
windows程序設計(1)
生活(2)
數(shù)據(jù)結構與算法(5)
數(shù)學(1)
圖形學
物理
游戲(1)
隨筆檔案
(11)
2009年9月 (3)
2009年8月 (8)
相冊
宇多田光
搜索
積分與排名
積分 - 15414
排名 - 961
最新評論
1.?re: 生成隨機數(shù)的一個工具類
能否解釋下什么原理不?這里的魔數(shù)真不少
--shilei230
2.?re: 讓我們這些中國二流大學的學生也聽聽世界一流大學的計算機課程(轉)
太好了,多謝博主!
--鄧強
3.?re: 讓我們這些中國二流大學的學生也聽聽世界一流大學的計算機課程(轉)
是的師傅是大方
--羅萊家紡
4.?re: 讓我們這些中國二流大學的學生也聽聽世界一流大學的計算機課程(轉)
不錯~分享了
--樂蜂網(wǎng)
5.?re: 讓我們這些中國二流大學的學生也聽聽世界一流大學的計算機課程(轉)
牛
--李佳
閱讀排行榜
1.?讓我們這些中國二流大學的學生也聽聽世界一流大學的計算機課程(轉)(4584)
2.?各種排序算法性能測試結果(2160)
3.?生成隨機數(shù)的一個工具類(1952)
4.?簡單的測試各種排序算法的性能(1752)
5.?計算幻方(1490)
評論排行榜
1.?讓我們這些中國二流大學的學生也聽聽世界一流大學的計算機課程(轉)(9)
2.?簡單的測試各種排序算法的性能(4)
3.?各種排序算法性能測試結果(2)
4.?暴雪CEO解讀吸引全球千萬玩家的商業(yè)秘密(2)
5.?生成隨機數(shù)的一個工具類(1)
6.?以后不能逃課了(1)
7.?計算幻方(1)
8.?計算以t為根的子樹的結點個數(shù)(0)
9.?一個簡單的計算程序運行時間的工具類(0)
10.?erroe C2471解決辦法(0)
11.?2009年9月語言排行榜:PHP超越C++(轉自CSDN:我鐘愛的C++和python啊)(0)
Powered by:
博客園
模板提供:
滬江博客
Copyright ©2025 diwayou
久久av高潮av无码av喷吹
|
人妻久久久一区二区三区
|
国内精品九九久久久精品
|
国产亚洲综合久久系列
|
韩国三级中文字幕hd久久精品
|
久久精品成人免费观看97
|
亚洲国产精品狼友中文久久久
|
久久久精品国产sm调教网站
|
久久久精品免费国产四虎
|
国内精品久久久久久久coent
|
中文字幕亚洲综合久久菠萝蜜
|
国产精品无码久久综合
|
久久av免费天堂小草播放
|
国内精品人妻无码久久久影院导航
|
久久国产色AV免费看
|
色欲综合久久躁天天躁
|
国产成人久久精品一区二区三区
|
久久久久亚洲AV无码专区桃色
|
国产精品久久国产精品99盘
|
久久久久亚洲AV无码专区网站
|
无码国内精品久久人妻蜜桃
|
亚洲国产成人精品女人久久久
|
亚洲国产天堂久久综合
|
狠狠干狠狠久久
|
人妻无码αv中文字幕久久琪琪布
|
青草影院天堂男人久久
|
久久99精品国产麻豆
|
久久精品中文字幕一区
|
欧美精品一区二区久久
|
久久久久久综合一区中文字幕
|
久久精品一本到99热免费
|
亚洲精品午夜国产va久久
|
精品国产综合区久久久久久
|
久久国产精品国产自线拍免费
|
色婷婷久久综合中文久久蜜桃av
|
日本久久中文字幕
|
久久久久亚洲AV综合波多野结衣
|
久久久99精品成人片中文字幕
|
91精品国产乱码久久久久久
|
AV狠狠色丁香婷婷综合久久
|
成人妇女免费播放久久久
|