Форум программистов, компьютерный форум CyberForum.ru

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 24, средняя оценка - 4.63
Enzzio
10 / 12 / 2
Регистрация: 29.05.2010
Сообщений: 295
#1

Генерация случайных чисел с использованием srand и библиотеки time может выдавать одинаковые числа, если... - C++

05.12.2011, 00:33. Просмотров 2976. Ответов 2
Метки нет (Все метки)

... если интервал случайных чисел, из которых идет отбор больше требуемого кол-ва случайных чисел?

Например: есть интервал (0-2000), из него требуется случайно получить 1000 значений. Будет ли получена хотя бы одна пара одинаковых значений?

P.S. Имхо, но вопрос и ответ возможно достойны F.A.Q.
Спасибо!
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
05.12.2011, 00:33     Генерация случайных чисел с использованием srand и библиотеки time может выдавать одинаковые числа, если...
Посмотрите здесь:

C++ srand(time(0))
C++ Генерация случайных чисел
C++ Генерация случайных чисел
C++ генерация случайных чисел
Генерация случайных чисел C++
Генерация случайных чисел С++ C++
C++ Генерация случайных чисел
C++ Генерация случайных чисел
генерация случайных чисел C++
C++ Генерация случайных чисел
C++ Как сделать подбор рандомный разных чисел (srand (time(0) не помогает)?
Реализовать генерацию случайных чисел с помощью функции srand() C++

Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Kidasov
77 / 77 / 12
Регистрация: 02.12.2011
Сообщений: 966
Записей в блоге: 3
05.12.2011, 00:54     Генерация случайных чисел с использованием srand и библиотеки time может выдавать одинаковые числа, если... #2
Конечно будет, если вы используете функции rand() srand() они генерируют псевдослучайную последовательность, а именно последовательность, подчиняющуюся конкретному распределению.
Для полностью случайных чисел используют аппаратные генераторы http://habrahabr.ru/blogs/DIY/133320/
easybudda
Эксперт С++
9412 / 5435 / 917
Регистрация: 25.07.2009
Сообщений: 10,428
05.12.2011, 01:15     Генерация случайных чисел с использованием srand и библиотеки time может выдавать одинаковые числа, если... #3
Цитата Сообщение от Enzzio Посмотреть сообщение
Имхо, но вопрос и ответ возможно достойны F.A.Q.
На самом деле это какая-то простенькая задачка из теории вероятностей, в принципе ничего особо интересного.
C
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
32
33
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
 
void random_fill(int * arr, size_t count, const int bottom, const int top){
    while ( count-- )
        *arr++ = rand() % (top - bottom + 1) + bottom;
}
 
int * find_value(const int * arr, size_t count, const int value){
    return ( count == 0 ) ? NULL : ( *arr == value ) ? (int*)arr : find_value(arr + 1, count - 1, value);
}
 
#define NUM_ELEMENTS 1000
#define TOP_VALUE 2000
#define BOTTOM_VALUE 0
#define NUM_TESTS 10
 
int main(void){
    int arr[NUM_ELEMENTS];
    size_t i, j;
    
    srand(time(NULL));
    for ( i = 0; i < NUM_TESTS; ++i ){
        random_fill(arr, NUM_ELEMENTS, BOTTOM_VALUE, TOP_VALUE);
        for ( j = 0; j < NUM_ELEMENTS - 1; ++j )
            if ( find_value(&arr[j+1], NUM_ELEMENTS - j - 1, arr[j] ) )
                break;
        printf("Test #%d: doubling values %sfound.\n", i + 1, ( j < NUM_ELEMENTS - 1 ) ? "" : "not ");
    }
    
    return 0;
}
метод проб и ошибок Всё время выдаёт, что есть повторы. Попробуйте задавать разные количество элементов (только без фанатизма - массив всё-таки стековый, да и функция рекурсивная) и максимальное значение - увлекательно по-своему...
Yandex
Объявления
05.12.2011, 01:15     Генерация случайных чисел с использованием srand и библиотеки time может выдавать одинаковые числа, если...
Ответ Создать тему
Опции темы

Текущее время: 13:37. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru