|
|
Регистрация Восстановить пароль |
Повторная активизация e-mail |
Регистрация | Задать вопрос |
Заплачу за решение |
Новые сообщения |
Сообщения за день |
Расширенный поиск |
Правила |
Всё прочитано |
|
Опции темы | Поиск в этой теме |
23.10.2016, 05:52 | #1 |
Регистрация: 23.10.2016
Сообщений: 4
|
Задача на Си разложить на простые множители
Нужно разложить число с количеством до ста символов на простые множители, например число:
93286507371999205962977351361478938 82665803050839205919257403713922543 17064584855785088915745761 Результат: Простые множители: 995663^8 x 995669^8 |
23.10.2016, 09:45 | #2 |
Старожил
Регистрация: 15.02.2010
Сообщений: 15,708
|
Если бы это была такая простая задача, не было б ассиметричной криптографии. Есть несколько алгоритмов, но пребирать их долго.
|
23.10.2016, 12:21 | #3 |
Участник клуба
Регистрация: 14.05.2016
Сообщений: 1,793
|
Да, это правда.
Посмотри ознакомительные видеоролики на эту тему. Ну, сами ролики длинные (по полтора часа идут) а тебе надо только небольшие фрагменты. с 38:36 мин по 40:50 мин https://www.youtube.com/watch?v=WiOnBj9gMG4 с 44:59 мин по 46:25 мин https://www.youtube.com/watch?v=M5FkMt0KZZU Если не секрет, а зачем это тебе? |
23.10.2016, 19:56 | #4 | |
Регистрация: 23.10.2016
Сообщений: 4
|
Цитата:
Последний раз редактировалось Yacub; 23.10.2016 в 20:00. |
|
23.10.2016, 19:58 | #5 |
Форумчанин
Регистрация: 25.01.2015
Сообщений: 472
|
Если это лаба, то достаточно показать алгоритм и продемонстрировать его на сравнительно небольшом числе. Нужно только длинную арифметику реализовать.
Если длинную арифметику не обязательно реализовывать (допустим, лаба не по алгоритмам, а по моделированию чего-то), то можно взять готовую библиотеку в виде DLL - "gmp.dll". Если это более серьёзная лаба - к ней всегда прилагается методичка с описанием. |
23.10.2016, 23:17 | #6 |
Участник клуба
Регистрация: 14.05.2016
Сообщений: 1,793
|
Yacub, занести в программу очень длинное число - это не сложно. Я бы советовал использовать матрицу, а лучше вектор, целого типа (и конечно же я бы попробовал динамическое распределение памяти):
18.jpg А дальше, естественно, нужна писать "специальные законы" обработки таких "чисел". Хотя знаешь, на этом форуме иногда вплывает данная тема (ты не первый) и если поискать, то возможно, можно чего-то и найти... Ну вот например (буквально вчера): http://www.programmersforum.ru/showthread.php?t=298701 Правда там число представляли как строчку текста (когда будешь смотреть - обрати внимание на специально созданные "законы обработки"). Последний раз редактировалось ura_111; 23.10.2016 в 23:39. |
Похожие темы | ||||
Тема | Автор | Раздел | Ответов | Последнее сообщение |
Как в C++ разложить числа на простые множители? | BESTолочь | Помощь студентам | 11 | 16.04.2018 10:37 |
как разложить на множители ? | blessedness777 | C# (си шарп) | 3 | 15.11.2012 19:07 |
разложение на простые множители | pakusya | Помощь студентам | 2 | 19.12.2011 15:55 |
разложить число на простые множители и вывести результат | pakusya | Паскаль, Turbo Pascal, PascalABC.NET | 6 | 15.11.2008 03:07 |