隨機數表

隨機數表

隨機數表也稱亂數表,是由隨機生成的從0到9十個數字所組成的數表,每個數字在表中出現的次數是大致相同的,它們出現在表上的順序是隨機的。

隨機數表是統計工作者用計算機生成的隨機數組成,並保證表中每個位置上出現哪一個數字是等機率的,利用隨機數表抽取樣本保證了各個個體被抽取的機率相等。

基本介紹

  • 中文名:隨機數表
  • 外文名:random number table
  • 也稱:亂數表
  • 出現:在表上的順序是隨機的
  • 採用隨機號碼錶法抽取樣本
  • 意義:非主觀
簡介,內容,意義,步驟,用途,程式,

簡介

隨機數字表,是由 0~9 的數字隨機排列(沒有任何規律的)的表格,表中有各自獨立的數字2500個,從左到右橫排為行,從上至下堅排為列。 表格形式多種,用法也很多,使用時可根據研究對象總體所含的個體數來確定使用幾位隨機數字, 也就是可以根據需要把它當成任何數字來使用。而隨機數表法,是用隨機數字表代替簽號或簽筒的一種隨機取樣的方法。其優點有:一是簡單可行,抽樣前只需對研究對象進行順序編號,然後根據隨機抽出的編號與研究對象對號入座即可;二是能保證符合抽樣的“隨機化原則(所謂“隨機化”原則,是指在抽樣時使總體的每一個個體都有同等的機會被獨立地抽到樣本中來,即“機會均等”的原則。抽中與否全都是偶然的,使抽取的樣本更具代表性。

內容

03
47
43
73
86
36
96
47
36
61
46
98
63
71
62
97
74
24
67
62
42
81
14
57
20
42
53
32
37
32
16
76
02
27
66
56
50
26
71
07
32
90
79
78
53
12
56
85
99
26
96
96
68
27
31
05
03
72
93
15
55
59
56
35
64
38
54
82
46
22
31
62
43
09
90
16
22
77
94
39
49
54
43
54
82
17
37
93
23
78
84
42
17
53
31
57
24
55
06
88
77
04
74
47
67
63
01
63
78
59
16
95
55
67
19
98
10
50
71
75
33
21
12
34
29
78
64
56
07
82
52
42
07
44
28
57
60
86
32
44
09
47
27
96
54
49
17
46
09
62
18
18
07
92
46
44
17
16
58
09
79
83
86
19
62
26
62
38
97
75
84
16
07
44
99
83
11
46
32
24
23
42
40
54
74
82
97
77
77
81
07
45
32
14
08
62
36
28
19
95
50
92
26
11
97
00
56
76
31
38
37
85
94
35
12
83
39
50
08
30
42
34
07
96
88
70
29
17
12
13
40
33
20
38
26
13
89
51
03
74
56
62
18
37
35
96
83
50
87
75
97
12
25
93
47
99
49
57
22
77
88
42
95
45
72
16
64
36
16
00
16
08
15
04
72
33
27
14
34
09
45
59
34
68
49
31
16
93
32
43
50
27
89
87
19
20
15
37
00
49
(以上只是部分)

意義

真正的隨機數是使用物理現象產生的:比如擲錢幣、骰子、轉輪、使用電子元件噪音核裂變等等。這樣的隨機數發生器叫做物理性隨機數發生器,它們的缺點是技術要求比較高。
隨機數表隨機數表
而通常我們使用的隨機數表是使用偽隨機數,這些數列是“似乎”隨機的數,實際上它們是通過一個固定的、可以重複的計算方法產生的。計算機或計算器產生的隨機數有很長的周期性。它們不真正地隨機,因為它們實際上是可以計算出來的,但是它們具有類似於隨機數的統計特徵。
採用隨機號碼錶法抽取樣本,完全排除主觀挑選樣本的可能性,使抽樣調查有較強的科學性。

步驟

1、統一編號。即將總體中的所有研究對象進行統一編號,做成簽。 如果研究對象是10以內的,只取1位數,則編號是 1~9;如果研究對象在 1~99 之間的,取 2 位數,則編號是 01~99;如果研究對象在 1~999 之間的,取 3 位數,則編號是 001~999;其他依次類推。 然後充分混合,目的是使各樣本編號均勻分布,符合“機會均等 的原則。
2、確定行名。研究人員根據自己的需要或意願,在表上任選一行數字,由該行數字決定起點行的數。如選擇25 行,即從上往下第 25 行為起點行。 若選擇的數大於 50,則用該數減去 50,將所得餘數為起點行。 若選擇0 或 00 行,則以第 50 行為起點行。
3、確定列名。 列名的確定方法與行名的確定方法相同。
4、錄取號碼。行名和列名決定後,就可以所選擇的起始行數和起始列數的交叉點處的數為起始點, 然後, 按一定順序方向(如自左向右或自右向左,從上往下或由下而上)進行依次錄取號碼,遇到大於總體的號碼或重複的號碼,應該捨去不要,直至錄取到所抽取的樣本數滿額為止。 用上述方法所錄取到的號碼則是被隨機抽中的樣本。

用途

比如,對銀行來說,銀行的ID和密碼非常脆弱。如果有隨機數表,就可以防備此類事件。隨機數表是指為每個客戶指定各不相同的數字列表,申請時將該隨機數表分配給客戶,而不是按照一定的規律給出,這就安全很多。
再比如,要考察某公司的牛奶產品質量,想從800袋牛奶中抽取60袋,就可以在隨機數表中選中一數,並用向上、下、左、右不同的讀法組成60個數,並按牛奶的標號進行檢測,雖然麻煩,但很常用。
詳細的舉一例:某企業要調查消費者對某產品的需求量,要從95戶居民家庭中抽選10戶居民碼錶法抽選樣本。具體步驟如下:  第一步:將95戶居民家庭編號,每一戶家庭一個編號,即01~95。(每戶居民編號為2數)
第二步:在上面的表中,隨機確定抽樣的起點和抽樣的順序。假定從第一行,第5列開始抽,抽樣順序從左往右抽。(橫的數列稱“行”,縱的數列稱為“列”)
第三步:依次抽出號碼分別是:86、36、96、47、36、61、46、98、63、71,共10個號碼。由於96、98兩個號碼不在總體編號範圍內,應排除在外。再補充兩個號碼:62、74。
由此產生10個樣本單位號碼為:86、36、47、61、46、63、71、62、74、24。
編號為這些號碼的居民家庭就是抽樣調查的對象。
實際生活中,這些隨機數表起著很大的作用,所以很多人會專門去尋找隨機數表產生器。

程式

在C語言中,rand()函式可以用來產生隨機數,但是這不是真正意義上的隨機數,是一個偽隨機數,是根據一個數,我們可以稱它為種子,為基準以某個遞推公式推算出來的一係數,當這系列數很大的時候,就符合常態分配,從而相當於產生了隨機數,但這不是真正的隨機數,當計算機正常開機後,這個種子的值是定了的,除非你破壞了系統,為了改變這個種子的值,C提供了srand()函式,它的原形是void srand( int a)。初始化隨機產生器即rand()函式的初始值,即使把種子的值改成a; 從這你可以看到通過srand()函式,我們是可以產生可以預見的隨機序列。那我們如何才能產生不可預見的隨機序列呢?我們可能常常需要這樣的隨機序列。利用srand((unsign)(time(NULL))是一種方法,因為每一次運行程式的時間是不同的。在C語言裡所提供的隨機數發生器的用法:現在的C編譯器都提供了一個基於ANSI標準偽隨機數發生器函式,用來生成隨機數。它們就是rand()和srand()函式。這二個函式的工作過程如下:
1) 首先給srand()提供一個種子,它是一個unsigned int類型,其取值範圍從0~65535;
2) 然後調用rand(),它會根據提供給srand()的種
3) 根據需要多次調用rand(),從而不間斷地得到新的隨機數;
4) 無論什麼時候,都可以給srand()提供一個新的種子,從而進一步“隨機化”rand()的輸出結果。
下面是0~32767之間的隨機數程式:
#include <stdlib.h>
#include <stdio.h>
#include <time.h> //使用當前時鐘做種子
void main( void )
{int i;
srand( (unsigned)time( NULL ) ); //初始化隨機數
for( i = 0; i <10;i++ ) //列印出10個隨機數
printf( " %d\n", rand() );
}
根據上面的程式可以很容易得到0~1之間的隨機數:
#include <stdlib.h>
#include <stdio.h>
#include <time.h>
main( )
{int i;
srand( (unsigned)time( NULL ) );
for( i = 0; i < 10;i++ )
printf( "%5.2f\n", rand()/32767.0);
}
而產生1~100之間的隨機數可以這樣寫:
#include <stdlib.h>
#include <stdio.h>
#include <time.h>
main( )
{int i;
srand( (unsigned)time( NULL ) );
for( i = 0; i < 10;i++ )
printf( "%d\n", rand()%100+1);
}
__________________________________________________
include <stdio.h>
#include <stdlib.h>
#include <time.h>
void main()
{
int i;
srand((unsigned)time(NULL));
i = rand() % 100;
}
這樣產生的隨機數就是0-99之間的,
這二個函式的工作過程如下:
1) 首先給srand()提供一個種子,它是一個unsigned int類型,其取值範圍從0~65535;
2) 然後調用rand(),它會根據提供給srand()的種子值返回一個隨機數(在0到32767之間)
3) 根據需要多次調用rand(),從而不間斷地得到新的隨機數;
4) 無論什麼時候,都可以給srand()提供一個新的種子,從而進一步“隨機化”rand()的輸出結果。
#include <stdlib.h>
#include <time.h>
main
{
int i;
srand(time(0)); //初始化隨機種子
i = rand(); //產生隨機數
}
首先,加一個"#include<stdlib.h>
然後設一個變數,如j,j=rand(),就可以給j賦一個1~32767的隨機數,如果要獲得一個隨機函式的十位(其它類似),只需令j=j/10就行. 添加頭檔案 #include<time.h> 然後在檔案中添加 srand((unsigned)time(NULL));
srand()是用來初始化隨機種子數的,因為rand的內部實現是用線性同餘法做的,它不是真的隨機數,只不過是因為其周期特別長,所以有一定的範圍里可看成是隨機的. 上面是有個隨機種子的說明及方法,為了避免重複.然後再 用 隨機函式,rand() 就行了.頭檔案是stdlib.h
random() 產生隨機數為 0或1
random(n) 產生隨機數為 0到n之間的一個隨機數
rand() 產生 0到32768之間的一個隨機數

相關詞條

熱門詞條

聯絡我們