|
3 / 3 / 0
Регистрация: 03.06.2019
Сообщений: 64
|
||||||
Как можно оптимизировать решение данной задачи?08.01.2020, 23:35. Показов 3426. Ответов 28
Метки нет (Все метки)
Всем привет!
Есть задачка, вот условие: Напишите функцию, которая принимает в качестве параметра целое число n и возвращает true, если число n! % (n^2) == 0. Вроде все понятно, вот только задача непростая, ведь максимум n, для которого она хоть что-либо может предложить(если делать по-простому, то есть считать каждое выражение), это примерно 20-25. Дальше все. Поэтому вот алгоритм, по которому делал я: Разбил число n ^ 2 на делители, поместил в масив nPw. Разбил числа от 1 до n на делители, поместил в values. Вычеркнул общие члены для массивов; если в nPw остались элементы, то число n! не делится на n ^ 2. Если что, вот код:
Подскажите, плиз, как можно оптимизировать алгоритм и почему, как вы думаете, вылазит ошибка?
0
|
||||||
| 08.01.2020, 23:35 | |
|
Ответы с готовыми решениями:
28
Как можно оптимизировать программу? Как можно оптимизировать код? |
|
4070 / 2704 / 433
Регистрация: 09.09.2017
Сообщений: 12,023
|
|||||||||||||||||
| 10.01.2020, 12:07 | |||||||||||||||||
Сообщение было отмечено nalbe666 как решение
Решение
Интересным образом работает даже проверка числа на простоту. Точного математического доказательства у меня пока нет, но если число n является составным, оно проходит почти все тесты, кроме 1 и 4, по крайней мере до 100`000, причем делает это мгновенно (9 мс против 76 сек моего предыдущего варианта). В связи с этим два вопроса: Почему оно работает? Почему оно не работает на четверке? Добавлено через 1 час 11 минут Попытаюсь подвести теорию и алгоритм под вычисление через простые числа. Случай первый: n - простое. Чтобы n! делилось на n2 надо чтобы (n-1)! делилось на n, то есть из множителей 1...(n-1) можно было собрать n. Но n - простое, а значит по определению не может быть представлено как произведение. Следовательно, (n-1)! на n не делится, ответ - FALSE. Случай второй: n - составное, то есть n=a*b, где 1<a,b<n. Если a!=b, то оба эти числа входят в последовательность факториала, а значит факториал делится на оба этих числа, а значит, и на n. Если же a==b, то чуть сложнее, ведь каждое число из последовательности входит в факториал только по одному разу. Но число может туда входить как сомножитель другого числа, то есть c = b*k, причем b=a ; k>1 ; 1<c<n, что эквивалентно b*k<n. Наименьшее k, которое может удовлетворять этому условию, равно 2. Подставляем n=a*b = a2. 1<a,b<n => a,2a < n => 2a<n => 2a<a2 => a>2. Таким образом, даже если оба сомножителя равны (n является квадратом), единственный случай, когда условие задачи не будет выполнено = квадрат двойки. Иначе говоря, число 4 - единственное исключение для квадратов. Результат: (n-1)! делится на n без остатка в любом случае за исключением простых n и n==4. В виде кода это выглядит так:
2
|
|||||||||||||||||
|
Диссидент
27714 / 17332 / 3810
Регистрация: 24.12.2010
Сообщений: 38,978
|
|||
| 10.01.2020, 12:40 | |||
|
0
|
|||
|
Just Do It!
|
|||||||
| 10.01.2020, 13:07 | |||||||
|
я уже написал, что выдает мой код, но ради вас повторюсь: на 1318, 2800 он выдает TRUE. Обратите внимание, что не 1, и не 0, и не true, а именно: большими буковками TRUE ![]() Кликните здесь для просмотра всего текста
0
|
|||||||
|
4070 / 2704 / 433
Регистрация: 09.09.2017
Сообщений: 12,023
|
||||
| 10.01.2020, 13:56 | ||||
|
Да даже long long переполниться может. Например, как вам 9223372036854775783? Сейчас поищу еще чиселки поменьше
1
|
||||
|
Диссидент
27714 / 17332 / 3810
Регистрация: 24.12.2010
Сообщений: 38,978
|
|
| 10.01.2020, 18:48 | |
|
COKPOWEHEU, Можно сформулировать такую "теорему"
Число n > 4 является простым тогда и только тогда, когда (n-1)! не делится на n Доказательство в вашем посте 22 Эквивалентная формулировка (возвращаясь к стартовому посту) Число n > 4 является простым тогда и только тогда, когда n! не делится на n2
0
|
|
|
4070 / 2704 / 433
Регистрация: 09.09.2017
Сообщений: 12,023
|
||
| 10.01.2020, 22:24 | ||
|
Фактически, вы сформулировали теорему, обратную моей: "число n! делится на n2 без остатка тогда и только тогда, когда оно не является простым и не равно 4".
0
|
||
|
Диссидент
27714 / 17332 / 3810
Регистрация: 24.12.2010
Сообщений: 38,978
|
||
| 10.01.2020, 22:42 | ||
![]() Теорема ровно та же, но другими словами. Впрочем, дальше уже скучно...
0
|
||
|
4070 / 2704 / 433
Регистрация: 09.09.2017
Сообщений: 12,023
|
||
| 11.01.2020, 02:31 | ||
|
0
|
||
| 11.01.2020, 02:31 | |
|
Как можно оптимизировать данный код? Можно как-то оптимизировать этот код?
Как составить формулу для данной задачи Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Сам себя обучал rest api
anaschu 02.07.2026
Педагогический лайфхак: Почему чистый REST API для ученика намного круче, чем готовые библиотеки
Когда мы отказались от капризного JAR-файла AnyLogic и переписали код на стандартный HttpClient,. . .
|
rest api anylogic - выполнение модели на своём русском сайте
anaschu 02.07.2026
Как подружиться с AnyLogic Cloud API, победить провайдеров и развернуться Java-бэкенд в Docker на бесплатном хостинге: Двухдневный лог борьбы
Всем привет! Хочу поделиться свежим (и довольно. . .
|
Где деньги лежат
kumehtar 02.07.2026
Это - японская подводная лодка I-52 (тип C2, кодовое имя Momi) вышла из Японии в марте 1944 года с миссией в оккупированную немцами Францию (Лорьян). Это была одна из «Янаги»-миссий по обмену. . .
|
Krabik для WoW 3.3.5a, многоязычный
AmbA 02.07.2026
Допилил бота, думаю что окончательно. Изменения:
- добавлена многоязычность
- добавлено снятие скриншотов
- добавлено поддержание бафов хождения по воде (для жреца, дк и шамана)
- и так, по. . .
|
|
Алиса нашла кучу ошибок компиляции и запуска в проекте, который без проблем компилировался и запускался)))
anaschu 30.06.2026
Я пока посмеюся, но завтра проверю. А вообще интерсно. Дал алисе файл, в котором точно нет ошибок компиляции и запуска, и попросил их найти. Нашла кучу)))
Критические ошибки, мешающие компиляции и. . .
|
сукцессия 16. Общий обзор, в основном что бы другие ии поняли
anaschu 29.06.2026
# Передаточный документ: модель микоризной сукцессии (для нового чата)
Этот документ предназначен для того, чтобы новый чат Claude мог продолжить
работу без необходимости заново разбираться в. . .
|
сукцессия 15 неявная схема
anaschu 29.06.2026
Алиса
Калибровка параметров симбиотической модели: технический обзор
Содержание:
Введение
Постановка проблемы
Технические аспекты реализации
Процесс внедрения изменений
|
сукцессия 14. Обновленная схема модели
anaschu 28.06.2026
ГЛОБАЛЬНАЯ ОПИСАТЕЛЬНАЯ СПЕЦИФИКАЦИЯ ЭКОСИСТЕМНОЙ МОДЕЛИ «SOIL CHEMISTRY & MYCORRHIZA 2. 0»
https:/ / ibb. co/ NnkGpfMd
Представленная интегрированная схема описывает непрерывную нелинейную. . .
|