Форум программистов
 

Восстановите пароль или Зарегистрируйтесь на форуме, о проблемах и с заказом рекламы пишите сюда - alarforum@yandex.ru, проверяйте папку спам!

Вернуться   Форум программистов > IT форум > Помощь студентам
Регистрация

Восстановить пароль
Повторная активизация e-mail

Купить рекламу на форуме - 42 тыс руб за месяц

Ответ
 
Опции темы Поиск в этой теме
Старый 23.10.2016, 05:52   #1
Yacub
 
Регистрация: 23.10.2016
Сообщений: 4
По умолчанию Задача на Си разложить на простые множители

Нужно разложить число с количеством до ста символов на простые множители, например число:
93286507371999205962977351361478938 82665803050839205919257403713922543 17064584855785088915745761
Результат:
Простые множители: 995663^8 x 995669^8
Yacub вне форума Ответить с цитированием
Старый 23.10.2016, 09:45   #2
p51x
Старожил
 
Регистрация: 15.02.2010
Сообщений: 15,708
По умолчанию

Если бы это была такая простая задача, не было б ассиметричной криптографии. Есть несколько алгоритмов, но пребирать их долго.
p51x вне форума Ответить с цитированием
Старый 23.10.2016, 12:21   #3
ura_111
Участник клуба
 
Регистрация: 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


Если не секрет, а зачем это тебе?
ura_111 вне форума Ответить с цитированием
Старый 23.10.2016, 19:56   #4
Yacub
 
Регистрация: 23.10.2016
Сообщений: 4
По умолчанию

Цитата:
Сообщение от ura_111 Посмотреть сообщение
Да, это правда.
Посмотри ознакомительные видеоролики на эту тему. Ну, сами ролики длинные (по полтора часа идут) а тебе надо только небольшие фрагменты.

с 38:36 мин по 40:50 мин
https://www.youtube.com/watch?v=WiOnBj9gMG4

с 44:59 мин по 46:25 мин
https://www.youtube.com/watch?v=M5FkMt0KZZU


Если не секрет, а зачем это тебе?
Задание в университете, суть в том что простые числа будут не больше 10^6, но как сделать чтоб программа воспринимала числа в которых до ста символов, я не представляю

Последний раз редактировалось Yacub; 23.10.2016 в 20:00.
Yacub вне форума Ответить с цитированием
Старый 23.10.2016, 19:58   #5
FPaul
Форумчанин
 
Регистрация: 25.01.2015
Сообщений: 472
По умолчанию

Если это лаба, то достаточно показать алгоритм и продемонстрировать его на сравнительно небольшом числе. Нужно только длинную арифметику реализовать.

Если длинную арифметику не обязательно реализовывать (допустим, лаба не по алгоритмам, а по моделированию чего-то), то можно взять готовую библиотеку в виде DLL - "gmp.dll".

Если это более серьёзная лаба - к ней всегда прилагается методичка с описанием.
FPaul вне форума Ответить с цитированием
Старый 23.10.2016, 23:17   #6
ura_111
Участник клуба
 
Регистрация: 14.05.2016
Сообщений: 1,793
По умолчанию

Yacub, занести в программу очень длинное число - это не сложно. Я бы советовал использовать матрицу, а лучше вектор, целого типа (и конечно же я бы попробовал динамическое распределение памяти):

18.jpg


А дальше, естественно, нужна писать "специальные законы" обработки таких "чисел".

Хотя знаешь, на этом форуме иногда вплывает данная тема (ты не первый) и если поискать, то возможно, можно чего-то и найти... Ну вот например (буквально вчера):

http://www.programmersforum.ru/showthread.php?t=298701

Правда там число представляли как строчку текста (когда будешь смотреть - обрати внимание на специально созданные "законы обработки").

Последний раз редактировалось ura_111; 23.10.2016 в 23:39.
ura_111 вне форума Ответить с цитированием
Ответ


Купить рекламу на форуме - 42 тыс руб за месяц



Похожие темы
Тема Автор Раздел Ответов Последнее сообщение
Как в 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