Logo Море(!) аналитической информации!
IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware
Архив форумов ЦИТФорума
Море(!) вопросов - Море(!) ответов
 
 FAQFAQ   ПоискПоиск   ПользователиПользователи   ГруппыГруппы   РегистрацияРегистрация 
 ПрофильПрофиль   Войти и проверить личные сообщенияВойти и проверить личные сообщения   ВходВход 
Как правильно задавать вопросы

Хорошая генерация случайного числа в заданном диапазоне (C).

 
Перейти:  
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Программирование
Предыдущая тема :: Следующая тема  
Автор Сообщение
Yello



Зарегистрирован: 09.03.2006
Сообщения: 107

СообщениеДобавлено: Вт Янв 27 2009 11:25    Заголовок сообщения: Хорошая генерация случайного числа в заданном диапазоне (C). Ответить с цитатой

include time.h, math.h
Код:
srand(time(NULL));

А дальше - как ?
Понятно, что unsigned int rand() выдаст с.ч. от 0 до RAND_MAX, и вроде как, распределение равномерно (т.е. вероятность для каждого числа этого диапазона - одна и та же).
Надо "сузить" диапазон.
Смотрел - везде только "ламерский" пример (типа: rand() % n_max) - такое распределение неравномерно (если только n_max не делит RAND_MAX без остатка, тогда так можно).
Предлагаю обсудить.
............................
Есть ли какая-то стандартная ф-я (как rand(), но с параметрами) ?
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
Benzedrin



Зарегистрирован: 04.04.2008
Сообщения: 34
Откуда: Minsk

СообщениеДобавлено: Вт Мар 17 2009 10:57    Заголовок сообщения: Ответить с цитатой

задай СВ по нужному закону распределения сам
http://window.edu.ru/window_catalog/pdf2txt?p_id=1609

только походу ты придираешься:
графиком функции распределения будет ступенчатая ф-я от 0 до rand_max. при умножении(а следовательно и делении) выходного значения ф-я распределения все-равно остается ступенькой, как не крути...
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
Yello



Зарегистрирован: 09.03.2006
Сообщения: 107

СообщениеДобавлено: Пт Апр 03 2009 22:11    Заголовок сообщения: Ответить с цитатой

Цитата:
при умножении(а следовательно и делении)

только если (RAND_MAX + 1) делится без остатка (на этот делитель).
Иначе - нет.
Маленький пример:

Пусть RAND_MAX = 9, и можно генерить (равномерно) целые числа от 0 до 9.

Смотрите, что будет при делении, например на 4.

0 1 2 3
4 5 6 7
8 9
---------
0 1 2 3 - результат от деления (после операции "%").

Вероятность в результате получить "3" и "2" меньше, чем "0" и "1".


И так будет всегда, когда нижняя строка не "выровнена" до конца (а это и есть... делимость того, что я говорил).
.
.
Цитата:
только походу ты придираешься

ну, не без этого.
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
Показать сообщения:   
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Программирование Часовой пояс: GMT + 3
Страница 1 из 1

 
Перейти:  
Вы не можете начинать темы
Вы не можете отвечать на сообщения
Вы не можете редактировать свои сообщения
Вы не можете удалять свои сообщения
Вы не можете голосовать в опросах


Powered by phpBB © 2001, 2002 phpBB Group
Русская поддержка phpBB

 

IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware

Информация для рекламодателей PR-акции, размещение рекламы — adv@citforum.ru,
тел. +7 495 6608306, ICQ 232284597
Пресс-релизы — pr@citforum.ru
Послать комментарий
Информация для авторов
This Web server launched on February 24, 1997
Copyright © 1997-2000 CIT, © 2001-2006 CIT Forum
Внимание! Любой из материалов, опубликованных на этом сервере, не может быть воспроизведен в какой бы то ни было форме и какими бы то ни было средствами без письменного разрешения владельцев авторских прав. Подробнее...