Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Скачиваний:
38
Добавлен:
20.05.2015
Размер:
2.45 Mб
Скачать

Программирование на языке Си

Тема 14. Случайные числа

© К.Ю. Поляков, 2007

157

Случайные числа

Случайные явления: везде…

бросание монеты ("орел" или "решка")

падение снега

броуновское движение

помехи при телефонной связи

шум радиоэфира

Случайные числа – это такая последовательность чисел, для которой невозможно предсказать следующее даже зная все предыдущие.

Проблема: как получить на компьютере?

Возможные решения:

использовать внешний источник шумовых помех

с помощью математических преобразований

158

Псевдослучайные числа

Псевдослучайные числа – это такая последовательность чисел, которая обладает свойствами случайных чисел, но каждое следующее число вычисляется по заданной формуле.

Примеры:

1. Случайные целые числа [0,m) (линейный конгруэнтный метод)

xn (a xn 1 c) mod m

a, c, m - целые числа

xn (16807 xn 1

12345) mod 1073741823

 

простое число

остаток от деления

230-1

2. Случайные вещественные числа [0,1]

xn ( xn 1 )k

например, k = 5

 

дробная часть числа

Литература:

Д. Кнут, Искусство программирования для ЭВМ, т.2.

159

Распределение случайных чисел

Модель: снежинки падают на отрезок [a,b]

распределение

равномерное

неравномерное

a

b

a

b

? Сколько может быть разных распределений?

160

Распределение случайных чисел

Особенности:

распределение – это характеристика всей последовательности, а не одного числа

равномерное распределение одно, компьютерные датчики (псевдо)случайных чисел дают равномерное распределение

неравномерных – много

любое неравномерное можно получить с помощью равномерного

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

a

 

x x b

 

a

b

 

 

x

1 2

 

 

x

x1 x2 x12

 

 

 

 

 

 

 

 

 

 

 

равномерное распределение

равномерное распределение

 

161

Генератор случайных чисел в Си

#include <stdlib.h>

// случайные числа

Целые числа в интервале [0,N]:

int x;

 

 

x = random ( 100 );

//

интервал [0,99]

x = random ( z );

//

интервал [0,z-1]

Целые числа в интервале [a,b]:

x = random ( z ) + a;

// интервал [a,z-1+a]

x = random (b – a + 1) + a; // интервал [a,b]

Установить начальное значение последовательности:

srand ( 345 );

// начнем с 345

Установить случайное начало последовательности: randomize ( );

162

Генератор случайных чисел в Си

Вещественные числа в интервале [0,1]

float x;

[0,RAND_MAX-1] = [0,32767]

x = 1.*rand() / RAND_MAX; // интервал [0,1)

Вещественные числа в интервале [0,z) x = 1.*z*rand()/RAND_MAX;

Вещественные числа в интервале [a,z+a) x = 1.*z*rand()/RAND_MAX + a;

Вещественные числа в интервале [a,b)

x = 1.*(b-a)*rand()/RAND_MAX + a;

163

Случайные числа

Задача: заполнить прямоугольник 400 на 300 пикселей равномерно точками случайного цвета

Как получить случайные координаты точки?

x = random ( 400 ); y = random ( 300 );

Как добиться равномерности?

обеспечивается автоматически при использовании функции random

Как получить случайный цвет?

color = random ( 16 );

случайный цвет выход по Esc
случайные координаты

164

Программа

#include <graphics.h> #include <conio.h>

#include <stdlib.h> void main()

{

int d = DETECT, m; int x, y, color;

initgraph ( &d, &m, "C:\\BORLANDC\\BGI" ); while ( 1 ) {

x = random(320)+160; y = random(240)+120; color = random(16);

putpixel ( x, y, color ); if ( kbhit() )

if ( 27 == getch() ) break;

}

closegraph();

}

165

Задания

"4": Ввести с клавиатуры координаты углов прямоугольника и заполнить его точками случайного цвета.

(100,100)

(300,200)

"5": Заполнить треугольник

точками случайного цвета (равномерно или неравномерно).

Подсказка: возьмите равнобедренный треугольник с углом 45о.

Соседние файлы в папке ПОЛЯКОВ_ПРЕЗЕНТАЦИИ_С++