|
63 / 64 / 11
Регистрация: 27.02.2013
Сообщений: 1,116
|
||||||
Продвинутый рандом (возможность задать рандомное число в нескольких диапазонах)22.09.2014, 22:00. Показов 5060. Ответов 44
Метки нет (Все метки)
закончил с лабами и от скуки написал продвинутую версию рандома
просто короче мне понадобилось чтобы можно было задать рандомное число в нескольких диапазонах, вот и не найдя готового решения написал сам, оценивайте ![]()
0
|
||||||
| 22.09.2014, 22:00 | |
|
Ответы с готовыми решениями:
44
Задать рандомное число
|
|
19501 / 10106 / 2461
Регистрация: 30.01.2014
Сообщений: 17,822
|
||||||||||||
| 23.09.2014, 19:44 | ||||||||||||
|
Выглядит конечно не очень понятно, но можно слегка причесать. Вынести метафункцияю проверки аргументов отдельно:
0
|
||||||||||||
|
1123 / 794 / 219
Регистрация: 15.08.2010
Сообщений: 2,185
|
||||||
| 23.09.2014, 19:53 | ||||||
|
DrOffset, поторопился, не все проверил: возникают ошибки при диапазоне типа (3,3) а так же если больше диапазонов использовать: Range{ 0, 0 }, Range{ 3, 4 }, Range{ 50, 100 } Не генерируются 50 и 3.
Код я ваш пока так и не осилил ввиду ужасного интернета, но потыркался оффлайн в переменных и циклах. единственное что понял: при диапазоне типа (3,3) к sum ничего не прибавляется. Вот добавил пару костылей, вроде работает:
1
|
||||||
|
19501 / 10106 / 2461
Регистрация: 30.01.2014
Сообщений: 17,822
|
|||||||
| 23.09.2014, 21:32 | |||||||
|
Индекс терялся при переходе к следующему диапазону. Вот пофиксил. Кликните здесь для просмотра всего текста
0
|
|||||||
|
63 / 64 / 11
Регистрация: 27.02.2013
Сообщений: 1,116
|
|
| 23.09.2014, 21:39 [ТС] | |
|
фига вы тут разошлись...
все ниасилю, но для начала что такое "...args" ?
0
|
|
|
19501 / 10106 / 2461
Регистрация: 30.01.2014
Сообщений: 17,822
|
|||||||||||||||||
| 24.09.2014, 14:54 | |||||||||||||||||
|
КОП, проблема была из-за того, что при переходе к след. диапазону не учитывалось, что индекс начинается с нуля. После того как мы это учили (в лямбде) наша последовательность съехала, т.к. получилось, что крайний индекс стал меньше на количество переходов. Поэтому нужно было добавить в начале это количество, что компенсировать верхний предел последнего диапазона. В случае, когда диапазон один, никакого дополнения не нужно, т.к. и переходов у нас нет (для этого там <кол-во аргументов> - 1).
Добавлено через 3 минуты ![]() Читай тут, ну и тут. Добавлено через 17 часов 8 минут Кстати, если диапазоны известны на этапе компиляции, то можно серьезно сократить результирующий код и увеличить быстродействие, фактически отказавшись от хранения данных о диапазонах и убрав циклы (засчет переноса некоторой части вычислений в compile-time). Результирующий код может выглядеть примерно так:
Код стал фактически эквивалентен такому (для случая [0;0], [3;4], [50;100]):
Весь код
Кстати, у этой реализации осталась одна багофича. Если задать два одинаковых диапазона или частично пересекающиеся, то числа из них будут генерироваться во столько раз чаще, сколько пересечений указано. Можно починить, трансформировав диапазоны из аргументов в другие, с исключением пересечений. А можно и не чинить, вдруг из этого можно будет получить како-либо полезный case
4
|
|||||||||||||||||
| 24.09.2014, 14:54 | |
|
Дать программе возможность самостоятельно выбрать число из нескольких введенных пользователем Подсчёт количества текстового значения ячейки в нескольких диапазонах Как сделать, чтобы random работал в нескольких диапазонах?
Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Программа для com-порта
Uhbif79 05.06.2026
Всем привет, давно хотел изучить Qt, начинал, бросал, потом снова начинал. И сейчас вот смог написать свою первую программу.
До этого имел опыт программирования микроконтроллеров, писал прошивки на. . .
|
Транскрипция 55-минутного видео через Whisper: WhisperDesktop облажался, спас Google Colab[
anaschu 01.06.2026
Понадобилось получить текст из свежезагруженного видео на YouTube. Казалось бы, задача на пять минут. Заняла полтора часа. Делюсь опытом — может кому пригодится последовательность решений.
. . .
|
21 мат мед. Планы на развитие модели здравоСохранения
anaschu 01.06.2026
AnyLogic: план развития симуляционной модели рабочего коллектива — динамический абсентеизм, реальные данные, три сценария сравнения
Продолжаю серию постов о дискретно-событийной модели рабочего. . .
|
20. Мат мед. Абсентеизм как отдельный тип простоя
anaschu 29.05.2026
Апдейт модели: исправленные баги, абсентеизм и новые механизмы
Продолжаю развивать ранее описанную модель рабочего коллектива на AnyLogic. За последние несколько дней был проведён серьёзный. . .
|
|
19. здоровье, усталость и психотип работника влияют на производительность предприятия, и наоборот, производительность на здоровье, усталось и психотип
anaschu 28.05.2026
Дискретно-событийная модель рабочего коллектива на AnyLogic: здоровье, выгорание, психотипы и микростимуляция
Привет, коллеги. Хочу поделиться итогами нескольких недель работы над симуляционной. . .
|
"Прокси" для последовательного порта
Eddy_Em 28.05.2026
Эту штуку написал я достаточно давно. Но сейчас вот понадобилось настроить датчик грозы, но при этом не отключать его от "метеодемона". Соответственно, надо запустить этот "прокси": метеодемон будет. . .
|
Рефакторинг программы уравнивания.
Massaraksh7 26.05.2026
Пример по предыдущей записи в блоге. Но, надо заметить, что, во-первых, там оптимизация не только математики, но и работы с базой данных, и с графами, а во-вторых, это ещё не всё.
|
Использование TThread в Lazarus для математических вычислений.
Massaraksh7 25.05.2026
Производя рефакторинг своих программ на предмет ускорения их работы, обратил внимание на такой аспект, как сокращение времени матвычислений. Дело в том, что приходится работать с большими матрицами. . .
|