С Новым годом! Форум программистов, компьютерный форум, киберфорум
PHP для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.64/11: Рейтинг темы: голосов - 11, средняя оценка - 4.64
0 / 0 / 0
Регистрация: 26.05.2010
Сообщений: 4
1

Генератор псевдослучайных чисел без использования встроеных функций php

03.12.2012, 18:37. Показов 2072. Ответов 1
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Здраствуйте,
нужна помощь в написании генератора псевдослучайных чисел с последующей проверкой метода для того чтоб доказать что полученое число - псевдослучайное. сделать надо без использования встроеных функций php.
Буду очень признателен если кто-то сможет помочь...
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
03.12.2012, 18:37
Ответы с готовыми решениями:

Как написать генератор чисел без использования стандартных функций?
Нужно написать программу генерирования равномерно распределенных случайных чисел без использования...

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

Генератор случайных чисел без использования стандартной функции
Нужен код генератора случайных чисел на c++ без использования функции rand(). Помогите пожалуйста ,...

Генератор случайных чисел без стандартных функций
Помогите пожалуйста. Нужно написать сой генератор случайных чисел без использования rand() ....

1
601 / 468 / 73
Регистрация: 22.01.2009
Сообщений: 1,180
Записей в блоге: 1
04.12.2012, 01:17 2
Лучший ответ Сообщение было отмечено Stirllitz как решение

Решение

один из самых простых алгоритмов генерации псевдослучайных чисел:
1. взять какое-то достаточно большое простое число (пусть это будет k)
2. взять любое начальное значение от 0 до 1 (например, 0.123456789), обозначим N
3. вычислить: N = frac(N * k) (взять дробную часть от произведения простого числа и предыдущего псевдослучайного).
В результате получается следующее псевдослучайное число в диапазоне [0..1], его можно привести к целому от [a..b] по формуле R = a + (b - a) * N
Далее повторяется шаг 3 для каждого нового числа последовательности (т.е. просто подставляется N). Уже, кажется, когда-то где-то было доказано, что получается достаточно длинная неповторяющаяся последовательность случайных чисел с равномерным распределением, которое, разумеется, можно привести к нормальному или любому другому по известным законам (уверен, что в википедии можно отыскать, при желании).
Вообщем, средствами php как-то так:
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
/**
 * @param int $a                Начало диапазона
 * @param int $b                Конец диапазона
 * @param null|float $seed      Начальное значение, получается, например, с помощью метки времени
 * @return int
 */
function myrand($a = 0, $b = 1, $seed = null) {
    static $N = 0.123456789;
    if (!is_null($seed)) {
        $N = $seed - (int)$seed;
    }
    $N = $N * 3571; // 3571 -- то самое простое число, разумеется, лучше найти побольше
    $N = $N - (int)$N * 1.0; // таким хитрым способом отбрасывается целая часть, функцию frac или ее аналог найти не могу
    return (int)($a + ($b - $a + 1) * $N);
}
 
myrand(0, 0, microtime(true) / 100000); // инициализация генератора
for ($i = 0; $i < 100; $i++) {
    echo myrand(1, 10), ' ';
}
есть подобный способ для int-овых чисел, но для пхп это наврядли сильно актуально.
еще один метод, легко реализуемый в пхп: берется двузначное число, возводится в квадрат. средние две цифры числа определяют следующий элемент последовательности.
качественно проверить полученную последовательность нетрудно: нужно всего лишь построить гистограмму (ну, или график, если хотите). что нужно для математически строгого доказательства не знаю.
1
04.12.2012, 01:17
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
04.12.2012, 01:17
Помогаю со студенческими работами здесь

Генератор псевдослучайных чисел.
Написать генератор псевдослучайных чисел по алгоритму r = r * 4231 + 123457; Подсчитать частоты...

Генератор псевдослучайных чисел
Народ, помогите плиз с решением этой задачи. Мне надо управляемый генератор равновесных...

Генератор псевдослучайных чисел
Модифицируйте программу так, чтобы элементы массива не вводились с клавиатуры, а генерировались...

Генератор псевдослучайных чисел
Всем привет! Необходима помощь с созданием генератора случайных чисел в MatLab, распределенных с...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Книги и учебные ресурсы по C#
InfoMaster 08.01.2025
Базовые учебники и руководства Одной из лучших книг для начинающих является "C# 10 и . NET 6 для начинающих" Эндрю Троелсена и Филиппа Джепикса . Книга последовательно раскрывает основные концепции. . .
Что такое NullReferenceEx­­­ception и как исправить?
InfoMaster 08.01.2025
NullReferenceException - одно из самых распространенных исключений, с которым сталкиваются разработчики на C#. Это исключение возникает при попытке обратиться к членам объекта (методам, свойствам или. . .
Что такое Null Pointer Exception (NPE) и как это исправить?
InfoMaster 08.01.2025
Null Pointer Exception (NPE) - это одно из самых распространенных исключений в Java, которое возникает при попытке использовать ссылку на объект, значение которой равно null. Это исключение относится. . .
Русский язык в консоли C++
InfoMaster 08.01.2025
При разработке программ на C++ одной из частых проблем, с которой сталкиваются русскоязычные программисты, является корректное отображение кириллицы в консольных приложениях. Эта проблема особенно. . .
Telegram бот на C#
InfoMaster 08.01.2025
Разработка ботов для Telegram стала неотъемлемой частью современной экосистемы мессенджеров. C# предоставляет мощный и удобный инструментарий для создания разнообразных ботов, от простых. . .
Использование GraphQL в Go (Golang)
InfoMaster 08.01.2025
Go (Golang) является одним из наиболее популярных языков программирования, используемых для создания высокопроизводительных серверных приложений. Его архитектурные особенности и встроенные. . .
Что лучше использовать при создании класса в Java: сеттеры или конструктор?
Alexander-7 08.01.2025
Вопрос подробнее: На вопрос: «Когда одновременно создаются конструктор и сеттеры в классе – это нормально?» куратор уточнил: «Ваш класс может вообще не иметь сеттеров, а только конструктор и геттеры. . .
Как работать с GraphQL на TypeScript
InfoMaster 08.01.2025
Введение в GraphQL и TypeScript В современной разработке веб-приложений GraphQL стал мощным инструментом для создания гибких и эффективных API. В сочетании с TypeScript, эта технология. . .
Счётчик на базе сумматоров + регистров и генератора сигналов согласования.
Hrethgir 07.01.2025
Создан с целью проверки скорости асинхронной логики: ранее описанного сумматора и предополагаемых fast регистров. Регистры созданы на базе ранее описанного, предполагаемого fast триггера. То-есть. . .
Как перейти с Options API на Composition API в Vue.js
BasicMan 06.01.2025
Почему переход на Composition API актуален В мире современной веб-разработки фреймворк Vue. js продолжает эволюционировать, предлагая разработчикам все более совершенные инструменты для создания. . .
Архитектура современных процессоров
inter-admin 06.01.2025
Процессор (центральный процессор, ЦП) является основным вычислительным устройством компьютера, которое выполняет обработку данных и управляет работой всех остальных компонентов системы. Архитектура. . .
История создания реляционной модели баз данных, правила Кодда
Programming 06.01.2025
Предпосылки создания реляционной модели В конце 1960-х годов компьютерная индустрия столкнулась с серьезными проблемами в области управления данными. Существовавшие на тот момент модели данных -. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru