Помощь - Поиск - Пользователи - Календарь
Полная версия: Алгоритмы генерации ППСЧ
Форум «Всё о Паскале» > Разработка ПО, алгоритмы, общие вопросы > Алгоритмы
klem4
Помогите найти инфу о сабже, конкретно интересует "конгруэнтный мультипликативный" алгоритм, кажется так называется unsure.gif
volvo
Google забанен? smile.gif

http://www.adss.onu.edu.ua/language/14.htm

Добавлено через 3 мин.
здесь тоже есть:
http://lserv.deg.gubkin.ru/mod/lesson/view.php?id=136
klem4
Цитата
Google забанен?

Гугл решает))))

Нажмите для просмотра прикрепленного файла

klem4
"Толи он чегото попутал, толи я чего-то не понял, с тех пор Константин Кинчев покинул наши кассетные магнитофоны" (с)

У меня начальные данные:

x0 = 0.11
A = 20
С = 2.8
k = 70

интересно, чему равно выражение

(20 * 0.11 + 2.8) mod 70 smile.gif)))))))))))))

Чем они там думаю когда тестовые задания пишут ... Ну или я туплю))

ps ну точнее 2.2 + 2.8 конечно же равно 5, но ! в любом случае это сумма чисел с плавающей точкой и никакой MOD тут не прокатит, ну а первый тестовый набор вообще решает ...

x0 = 0
A = 5.2
C = 0
k = 5

даже если округлить A до целого (5), то ...


x1 = (5 * 0 + 0) mod 5 = 0;
x2 = (5 * 0 + 0) mod 5 = 0;
...
xN = (5 * 0 + 0) mod 5 = 0;

smile.gif)))))))))))))))))))))))))))))))))
volvo
Цитата
интересно, чему равно выражение

(20 * 0.11 + 2.8) mod 70
blink.gif

5 mod 70 не знаешь нему будет равно? Выдыхай, klem, быстрее... smile.gif

А для дробных значений в Сях есть функция fmod, посмотри ее реализацию...
klem4
Цитата
5 mod 70 не знаешь нему будет равно? Выдыхай, klem, быстрее... smile.gif


я по этому поводу ps добавил)

Цитата
А для дробных значений в Сях есть функция fmod, посмотри ее реализацию...


Делать можно на чем угодно, вот пусть она мне на Паскале с такими исходными данными (2.2 + 2.8) mod 70 посчитает.
мисс_граффити
Ты путаешь математическое понятие остатка от деления с его реализацией в конкретном языке.
Смотри (с т.з. математики): у тебя 30 рублей, а мороженое стоит 7 рублей. Ты можешь купить 4 мороженых и 2 рубля - остаток.
У тебя 2р.30коп., а коробок спичек стоит 20 копеек. Можно ведь посчитать остаток (=сдачу) после покупки максимального колва коробков?
klem4
в данном конкретном случае рубли переводятся в копейки и все ок, НО !

http://slovari.yandex.ru/art.xml?art=gl_na.../6%26%26isu%3D2

Деление по модулю - арифметическая операция, результатом которой является остаток от деления целого числа на другое целое число.
volvo
Цитата
вот пусть она мне на Паскале с такими исходными данными (2.2 + 2.8) mod 70 посчитает

function fmod(x, y: double): double;
begin
fmod := Frac(x/y) * y;
end;

begin
writeln(fmod(2.2 + 2.8, 70): 10: 5);
end.


Я ж не просто так сказал: посмотри, как реализовано, и перенеси на нужный тебе язык...
klem4
Чтож спасибо, поюзаю эту формулу, но всеже первый контрольный вариант smile.gif Как быть с ним ?

Цитата
x0 = 0
A = 5.2
C = 0
k = 5


Это несомненно ошибка.
мисс_граффити
x0=0 - ошибка?
мне кажется, скорее специально подобранные данные. чтобы показать, насколько результат алгоритма зависит от начальных данных...
klem4
Все конечно возможно ... А если вернуться к определению этого метода, результатом должен быть набор чисел
x1, x2, ..., xN (- A, где A = {0, 1, 2, ...}

то есть целые числа ... возможно это не общее определение, но другого определения мне найти не удается.
Это текстовая версия — только основной контент. Для просмотра полной версии этой страницы, пожалуйста, нажмите сюда.