Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.76/25: Рейтинг темы: голосов - 25, средняя оценка - 4.76
 Аватар для Enzzio
72 / 30 / 4
Регистрация: 29.05.2010
Сообщений: 478

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

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

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

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

P.S. Имхо, но вопрос и ответ возможно достойны F.A.Q.
Спасибо!
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
05.12.2011, 00:33
Ответы с готовыми решениями:

Генерация случайных чисел с использованием микросхемы таймера
Приветствую всех! столкнулся с такой проблемой, задание: создать генератор случайных чисел используя таймер...можно без дополнительных мат....

Генератор случайных чисел генерирует одинаковые числа
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; using...

Генератор случайных чисел rand() выдаёт одинаковые числа
Например, сделаем маленькую программу в которой будет переменная int chislo. Дальше будет так: chislo = rand() + 1 % 10; cout <<...

2
80 / 79 / 35
Регистрация: 02.12.2011
Сообщений: 966
Записей в блоге: 3
05.12.2011, 00:54
Конечно будет, если вы используете функции rand() srand() они генерируют псевдослучайную последовательность, а именно последовательность, подчиняющуюся конкретному распределению.
Для полностью случайных чисел используют аппаратные генераторы http://habrahabr.ru/blogs/DIY/133320/
1
Модератор
Эксперт PythonЭксперт JavaЭксперт CЭксперт С++
 Аватар для easybudda
12843 / 7592 / 1766
Регистрация: 25.07.2009
Сообщений: 13,973
05.12.2011, 01:15
Цитата Сообщение от 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;
}
метод проб и ошибок Всё время выдаёт, что есть повторы. Попробуйте задавать разные количество элементов (только без фанатизма - массив всё-таки стековый, да и функция рекурсивная) и максимальное значение - увлекательно по-своему...
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
05.12.2011, 01:15
Помогаю со студенческими работами здесь

Как сделать подбор рандомный разных чисел (srand (time(0) не помогает)?
Здравствуйте, уважаемые программиты, не могли бы вы мне помочь? Дело в том, что мне нужно сделать генератор рандомных чисел. Я уже...

Реализовать генерацию случайных чисел с помощью функции srand()
Ребят, есть функция srand(time(NULL)). Хочу поместить ее в цикл, чтоб с клавиатуры вводить например 5, а функция возвращала на екран 5...

Задача такое нужно построить случайных величин и генерация случайных чисел(ГСЧ
Народ помогите тут надо. Задание такое нужно построить случайных величин и генерация случайных чисел(ГСЧ). Задние прикреплю.Там подробно...

srand(time(0))
Тут встретил такое выражение. Вы не скажете, что оно даёт, и как расшифровать этот код #include &lt;iostream&gt; #include...

Аналог srand(time(null)
Здравствуйте) Я сформировала строку из случайных символов, но столкнулась с проблемой: первый символ всегда пробел=( Знаю, что на С++...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru