реклама на сайте
подробности

 
 
> Обратное соответствие (x*y) mod z, Как нибудь аналитечески можно ли?
alexPec
сообщение Jan 19 2011, 21:34
Сообщение #1


Профессионал
*****

Группа: Свой
Сообщений: 1 284
Регистрация: 9-04-06
Пользователь №: 15 968



Добрый день, Уважаемые. Туплю че-то, подскажите пожалуйста.
Такая задача: найти обратное соответствие функции a = (x*y) mod z.
Известно: a,y,z, надо найти x. Кроме того, z<<y и точно известно, что соответствие между a и х однозначное.
Можно ли как то аналитически вычислить x, зная a? Можно конечно через таблицу, вычислить прямое соответствие а потом обратное искать, но память тратить на таблицу неохота.

Спасибо.
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
Xenia
сообщение Jan 19 2011, 23:08
Сообщение #2


Гуру
******

Группа: Модератор FTP
Сообщений: 4 479
Регистрация: 20-02-08
Из: Москва
Пользователь №: 35 237



Цитата(alexPec @ Jan 20 2011, 00:34) *
Такая задача: найти обратное соответствие функции a = (x*y) mod z.
Известно: a,y,z, надо найти x

Ответ: x = (n*z + a)/y, где n - любое натуральное число.
Проверка:
1) домножая обе части на y, получим:
x*y = n*z + a
2) берем модуль от обеих частей:
(x*y) mod z = (n*z+a) mod z = a
что совпадает c условием.
Go to the top of the page
 
+Quote Post
alexPec
сообщение Jan 20 2011, 07:27
Сообщение #3


Профессионал
*****

Группа: Свой
Сообщений: 1 284
Регистрация: 9-04-06
Пользователь №: 15 968



Цитата(Xenia @ Jan 20 2011, 02:08) *
Ответ: x = (n*z + a)/y, где n - любое натуральное число.
Проверка:
1) домножая обе части на y, получим:
x*y = n*z + a
2) берем модуль от обеих частей:
(x*y) mod z = (n*z+a) mod z = a
что совпадает c условием.


Спасибо Xenia, осмылю - отпишусь.
Go to the top of the page
 
+Quote Post
alexPec
сообщение Jan 20 2011, 10:15
Сообщение #4


Профессионал
*****

Группа: Свой
Сообщений: 1 284
Регистрация: 9-04-06
Пользователь №: 15 968



Осмыслил, но не понял как это может помочь в решении обратной задачи.

Чтоб было понятно о чем речь, это функция рандомизации последовательности от 0 до Z, упрощенный пример:

a=(x*13) mod 5

Соответствие такое, как видно однозначное (да, забыл упомянуть, 0<=x<z, х целое):

Х - а

0 - 0
1 - 3
2 - 1
3 - 4
4 - 2

Нужно по последовательности a восстановить последовательность Х

Че то даже на таком простом примере не соображу аналитическое решение обратной задачи.

Вопрос ставится уже так: имеет ли задача обратное решение (кроме табличного)?

Помню обрывками из криптографии, что однозначность только имеет прямая задача, а обратная однозначно не решается. Или я что-то путаю?

Если мысли мои верны, то подскажите, возможно ли как-то решить обратную задачу без таблицы, ну или таблицу не размером 2 x Z, а поменьше делать?

И еще раз спасибо.
Go to the top of the page
 
+Quote Post
Xenia
сообщение Jan 20 2011, 12:20
Сообщение #5


Гуру
******

Группа: Модератор FTP
Сообщений: 4 479
Регистрация: 20-02-08
Из: Москва
Пользователь №: 35 237



Цитата(alexPec @ Jan 20 2011, 13:15) *
Соответствие такое, как видно однозначное (да, забыл упомянуть, 0<=x<z, х целое)


Забыли сказать? Да вы просто издеваетесь! Может быть у вас еще y тоже целое?
Go to the top of the page
 
+Quote Post



Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 22nd July 2025 - 17:59
Рейтинг@Mail.ru


Страница сгенерированна за 0.01412 секунд с 7
ELECTRONIX ©2004-2016