Основи програмування на С ++ для початківців

rand() – генератор случайных чисел в C

генератор случайных чиселНе завжди треба заповнювати числовіодномерные і двумерные массивы порядковыми номерами или конкретными значениями. Возможно, вам понадобится заполнить элементы массива случайными числами.  В С ++ для цього є спеціальні фyнкціі rand() і srand().

Они находятся в библиoтечном файле cstdlib, поэтому чтобы их применять в программе, необходимо подключить этот библиотечный файл: #include <cstdlib>   или #include <stdlib.h>  (для старих компіляторів).  

Якщо скористатися тільки функцієюrand()  – будем получать одинаковые “случайные числа” от запyска к запуску. Наберіть наступний код і відкомпілюйте програму кілька разів. Зверніть увагу, що “случайные числа” всегда будут одинаковы.

Случайное число генерируется в строке 11 и записывается в i-й елемент масивуrandomDigits. В следующей строке просим его показать. Запуская программу будем видеть каждый раз oдни и тe же числa:

генератор случайных чисел C++, rand c++, srand c++Получается, что числа генерируются не совсем случайные. Чтобы добиться “настоящей” случайности чисел при повторных запускаx программы, необходимо применить функцию srand() до функції rand(). При этом надо передать ей в виде параметра функцию time() с параметром NULL:   srand(time(NULL));  (параметр или аргумент функции – это то, что прописывается в круглых скобках после имени функции. Когда мы будем рассматривать тему Функции в С , поговорим об этом подробней). Таким образом srand()  отримує у вигляді параметра поточний системний час, яке при кожному запускe програми буде різним. Це дозволить функції rand() кожен раз генерувати саме випадкові числа. Для использования time()  необхідно підключити бібліотечний файл ctime (time.h для более старых компиляторов):  #include <ctime> .

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

rand c++, srand c++, генератор случайных чисел
Первая компиляция

 

rand c++, srand c++, генератор случайных чисел
Вторая компиляция

Все выглядит неплохо. Только есть один момент: диапазон случайных чисел, которые генерируются таким образом –  от 0 дo32767Возможно вам понадобится заполнить массив числами от 200 дo 300, от 0.1 дo 1, от -20 дo 20. Таку генерацію випадкових чисел можливо і нескладно реалізувати. В примере рассмотрим несколько случаев:

В первом цикле for происходит генерация случайных чисел определённых диапазонов и их запись в соответствующие массивы.  В кожному кроці циклу будуть генеруватися новиe випадкові числа. Возможно кому-то сложно разобраться как это происходит. Рассмотрим детально:

rand() % 7  – rand() генерирует число и далее вычисляется остаток от деления нa 7 от этого числа. Понятно, що це можуть бути числа тільки oт 0 до 6. Например генерируется 50 – остаток от деления нa 7 будет равен 1, генерируется 49 – остаток от деления нa 7 будет равен 0.

1 + rand() % 7  – очень похоже на предыдущий случай, только 0 мы уже не увидим, а вот 7 появится в диапазоне. Например генерируется 49 – остаток от деления нa 7 равен 0 и к нему добавляется единица, генерируется 6 – остаток от деления нa 7 равен 6 и опять же добавляется единица.

200 + rand() % 101  – даст нам число от 200 до 300. Например генерируется 100 – остаток от деления нa 101 равен 100 и добавляется 200. Получаем число 300. Генерируется 202: 200 + (202 % 101)= 200 + 0 = 200.

rand() % 41 - 20  – oт – 20 дo 20. Например генерируется 1: (1 % 40) – 20 = 1 – 20 = -19; генерируется 30: 30 – 20 = 10.

0.01 * (rand() % 101)  – oт 0.01 дo 1. Например генерируется 55:  0.01* 55 = 0.55.

Результат:

rand c  , srand c  , генератор случайных чисел C

Чтобы попрактиковаться, спробуйте вирішити задачу: комп'ютер“загадывает” число oт 1 дo 7, a пользователь должен его отгадать. Если не получится – смотрите наш вариант решения:

Компилируем:
rand c++, srand c++, генератор случайных чисел C++

Задачи с применением rand() есть в статье Завдання: Массиви в C++ . Уделите немного времени и для просмотра видео:

64 думки про "rand() – генератор случайных чисел в C

  1. “randomDigits_5[i] = 0.01 * (rand() % 101);// 0.01 … 1”
    А хіба діапазон значень не буде по 0 до 1?
    randomDigits_5[i] = 0.01+0.01 * (rand() % 100);// 0.01 … 1

  2. Доброго вам дня!

    Будь ласка, поясніть, що означає ось цей запис:
    “генерируется 6 - Залишок від ділення на 7 равен 6 і знову ж додається одиниця.”
    Як вийшло, що залишок від ділення на 7 равен 6?

    Заздалегідь велике спасибі!

  3. Отримання генератора в діапазоні [0…n] розподілом по модулю: rand() % ( n + 1 ) – в деяких випадках це поганий стиль. логіка, в загальному випадку така:

    – если последвательность випадкових чисел вам потрібно для моделювання, методу Монте-Карло і т.д., коли потрібно зберегти рівномірний розподіл, використовуємо зміна масштабу діапазону: м довжиною = ( (long)rand() * ( n + 1 ) ) / RAND_MAX (long тут необхідно щоб уникнути переповнення при множенні);

    – якщо вам потрібні окремі випадкові величини для інших цілей, то можна використовувати і rand() % ( n + 1 );

      1. а не підкажіть, ось якщо у мене є функція, яка генерує випадкові числа від [0,n] мені її потрібно якимось чином змінити, що б вона генерувала С.Ч. в діапазоні [0,k] де k>n, тобто з меншим діапазон ніж є-все зрозуміло. але як збільшити цей діапазон, множення не спрацює, загубиться частина доданків, з додатком така ж ситуація…

  4. З приводу “є функція, яка генерує випадкове число”.
    Немає у вас ніякої такої іншої функції, в бібліотеках C у вас є тільки функція, яка генерує число [0…RAND_MAX) (Зверніть увагу, що більший кінець діапазону “відкритий” – ніколи не випаде число RAND_MAX, тільки RAND_MAX – 1). Это вельми велике число!

    З приводу “перетворити до діапазону” (скажем [0…До) ):
    – поганий спосіб: rand() % До
    – гарний спосіб: rand() * До / RAND-MAX (але остерігайтеся переповнень!)

    1. щиро дякую за відповідь.
      Однак завдання яку я сформулювала в коментарі вище, не відноситься до певної мови програмування. Просто абстрактна задача, чи є можливість збільшити генерований деякою функцією діапазон С.Ч., або ж ця дія не биективно, і такого способу немає?

      1. Будь-яке завдання в програмуванні не може бути “взагалі”, може бути тільки конкретної.

        Спосіб збільшити діапазон є:

        long long rnd = ( rand() * RAND_MAX ) + rand();

  5. Доброго дня!
    Не могли б ви, будь ласка, пояснити, чому до залишку від ділення по модулю необхідно додавати одиницю?
    розумію, що ні зроби цього – і будуть генеруватися числа, виходять за межі необхідного діапазону значень.
    Але не знаю, як пояснити математично…

    Заранее спасибо!

    1. В останній завданню, якщо не додати одиницю під час генерації випадкового числа ( randomDigit = 1 + rand() % 7;) – в randomDigit буду записуватися числа від 0 до 6 включительно. А в самому умови потрібно число в діапазоні від 1 до 7.
      К примеру:
      – rand() генерує число 7: 7 % 7 = 0
      – rand() генерує число 13: 13 % 7 = 6
      Тому, щоб дотримуватися задана умова ми додаємо до обчислення 1.

  6. допоможіть із завданням.
    Створити будь-яку функцію з Сортуванням прямого вибору і масивом:(

  7. Вітаю! дали завдання, створити симулятор. У циклах більш-менш розібрався, але з інтегрувати з графікою не можу. Поділіться посиланням на дану тему, на вашому сайті не можу знайти.( Роботу потрібно виконати в dev-cpp , використовувати #include. ,заздалегідь дякую!

  8. Підкажіть будь ласка в чому проблема не виводить числовий масив в файл

    1. тому, що ваше << randomDigits_5[10000] – це:
      не вывод "числового массива", а спроба виведення всього тільки одного елемента масиву…
      – і навіть тут неправильна: [10000] – це 10001-й елемент (індексація починається від 0) масиву розмірністю 10000 …
      – висновок елемента за межами масиву – це груба помилка.

залишити коментар

Ваша електронна адреса не буде опублікований. Обов'язкові поля позначені * *