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
管理
<
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)
數據結構與算法(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
精品久久777
|
无码人妻久久一区二区三区蜜桃
|
久久e热在这里只有国产中文精品99
|
国产亚洲美女精品久久久久狼
|
国产∨亚洲V天堂无码久久久
|
久久久久久久国产免费看
|
精产国品久久一二三产区区别
|
一本色道久久综合
|
亚洲一区二区三区日本久久九
|
青青热久久国产久精品
|
国产三级久久久精品麻豆三级
|
久久九九亚洲精品
|
久久99热只有频精品8
|
精品99久久aaa一级毛片
|
日韩人妻无码精品久久久不卡
|
亚洲美日韩Av中文字幕无码久久久妻妇
|
久久九九久精品国产
|
亚洲AV成人无码久久精品老人
|
国产高清美女一级a毛片久久w
|
国产精品久久久久影院色
|
色欲综合久久躁天天躁蜜桃
|
久久99精品国产99久久6男男
|
伊人久久大香线蕉成人
|
精品久久人人妻人人做精品
|
人妻精品久久无码区
|
热久久视久久精品18
|
蜜臀久久99精品久久久久久
|
青青草原综合久久大伊人
|
久久久久国产精品
|
99国产精品久久
|
国产精品99久久免费观看
|
99久久国产精品免费一区二区
|
久久人人爽人人精品视频
|
国产精品一区二区久久精品无码
|
精品伊人久久大线蕉色首页
|
久久久久亚洲AV成人网人人软件
|
乱亲女H秽乱长久久久
|
思思久久好好热精品国产
|
三级片免费观看久久
|
久久这里只有精品视频99
|
久久伊人亚洲AV无码网站
|