|
0 / 0 / 0
Регистрация: 28.03.2021
Сообщений: 40
|
|
Найдите все числа, принадлежащие заданному отрезку, у которых ровно пять различных нечётных делителей28.03.2021, 21:45. Показов 15572. Ответов 5
Метки нет (Все метки)
Здравствуйте,помогите написать программу на паскале(Abc или abc.net) с таким условием.
Задание на массивы. Найдите все натуральные числа, принадлежащие отрезку [35 000 000; 40 000 000],у которых ровно пять различных нечётных делителей (количество чётных делителей может быть любым). В ответе перечислите найденные числа в порядке возрастания. Заранее спасибо!
0
|
|
| 28.03.2021, 21:45 | |
|
Ответы с готовыми решениями:
5
Найти все целые числа из промежутка от 1 до 300, у которых ровно пять делителей Найти все целые числа из промежутка от 1 до 300, у которых ровно пять делителей |
|
2374 / 776 / 561
Регистрация: 15.01.2019
Сообщений: 2,394
|
||||||
| 28.03.2021, 23:13 | ||||||
Сообщение было отмечено AlexTry как решение
Решение
Программа находит за вменяемое время числа с 5 нечетными делителями только на отрезке [35000; 40000] На отрезке [35000000; 40000000] срок ожидания результата становится запредельным.
1
|
||||||
|
5095 / 2661 / 2355
Регистрация: 10.12.2014
Сообщений: 10,060
|
|||||||||||||||||||||||||||||||
| 29.03.2021, 08:04 | |||||||||||||||||||||||||||||||
|
Количество циклов можно значительно сократить:
Во-первых, если считать делителем 1 и само число, то зачем
i, достаточно до i div 2— делитель можно представить как нечётное число вида (j*2+1), где j=1…(i/4)
Даже для интервала 35 000…400 000 вместо 3 с копейками минут мой комп затратил всего 26 секунд. То, что не имеет смысла искать на интервале, который дал ТС, соглашусь. Даже без вывода всех делителей это будет очень затратно по времени. P.S. И про какие массивы тут речь? P.P.S. Строка count:= 1 + Ord(Odd(i)); в PABC без .NET не будет работать.Нужно так: count:=1; if Odd(i) then inc(count);
1
|
|||||||||||||||||||||||||||||||
|
0 / 0 / 0
Регистрация: 28.03.2021
Сообщений: 40
|
||||||
| 29.03.2021, 19:10 [ТС] | ||||||
|
Варианты сверху очень удобные,я сделал слегка более топорно,но оно вообще не работает,хотя ошибки нету,помогите если можете. Дело точно не в размере(миллионах),видел программы которые работали на подобных количествах элементов.
0
|
||||||
|
2374 / 776 / 561
Регистрация: 15.01.2019
Сообщений: 2,394
|
||||||
| 29.03.2021, 20:42 | ||||||
0
|
||||||
|
Модератор
10430 / 5718 / 3404
Регистрация: 17.08.2012
Сообщений: 17,387
|
|||||||||||
| 10.04.2021, 05:59 | |||||||||||
|
Если число нечётное, то оно имеет только нечётные делители.
Чтобы выделить нечётные делители чётного числа, нужно разделить число на такую степень двойки, чтобы число стало нечётным. Для этого можно делить число на 2 или сдвигать побитно вправо на 1 до тех пор, пока оно не станет нечётным. Но лучше разделить число на значение, равное весу самого младшего единичного разряда числа. Определить это значение легко с помощью побитовых операций: (not(x) + 1) and x. Число имеет нечётное количество делителей, только тогда, когда оно является полным квадратом. Любой делитель числа, за исключением делителя, являющегося квадратным корнем из числа, имеет пару. Если число является полным квадратом, три его делителя очевидны: это 1, квадратный корень из числа и само число. Таким образом, чтобы определить, имеет ли число ровно 5 нечётных делителей, нужно число сделать нечётным, поделив его на соответствующую степень двойки, и посчитать количество делителей от 3 до (корня квадратного из числа - 2). Если будет найден ровно 1 делитель, значит, число имеет ровно пять делителей: 1, квадратный корень из числа, само число, найденный делитель и парный ему делитель (само число, разделённое на найденный делитель). Естественно, проверять нужно только полные квадраты. Для любого диалекта паскаля:
Для Pascal ABC.NET:
0
|
|||||||||||
| 10.04.2021, 05:59 | |
|
Помогаю со студенческими работами здесь
6
Найти все целые числа из промежутка от 1 до 300, у которых ровно пять делителей.
Найти все целые числа из промежутка от 1 до 300, у которых ровно пять делителей 8.27. Найти все целые числа из промежутка от 1 до 300 у которых ровно пять делителей
Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога
Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
|
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование
. \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json>
Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом.
# Check if. . .
|
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так:
https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347
Основана на STM32F303RBT6.
На борту пять. . .
|
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
|
|
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу,
и светлой Луне.
В мире
покоя нет
и люди
не могут жить в тишине.
А жить им немного лет.
|
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила»
«Время-Деньги»
«Деньги -Пуля»
|
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога
Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
|
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога
Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
|