|
2 / 2 / 0
Регистрация: 03.05.2020
Сообщений: 202
|
|
Найти max количество подряд идущих элементов последовательности, которые делятся на одно и то же натуральное число19.07.2021, 13:31. Показов 5633. Ответов 20
Метки нет (Все метки)
Забавная игра
Вы с друзьями играете в следующую игру. Друзья пишут на доске подряд N натуральных чисел. Ваша задача — найти как можно больше подряд идущих чисел, которые бы делились на одно и то же число, большее 1. Так как вручную искать ответ сложно, вы решили написать программу, которая сделает работу за вас. Входные данные В первой строке входных данных задано число N(1 ≤ N ≤ 100000). Во второй строке записано через пробел N целых чисел A1...AN(1 ≤ Ai ≤ 1000, 1 ≤ i ≤ N). Это те самые числа, которые написали ваши друзья. Они даны в том же порядке, в котором они расположены на доске. Выходные данные Ваша программа должна вывести одно целое число — наибольшее количество подряд идущих чисел заданной последовательности, которые бы делились на одно и то же натуральное число, большее 1. Примеры Ввод 3 6 10 15 Dsdjl 2
0
|
|
| 19.07.2021, 13:31 | |
|
Ответы с готовыми решениями:
20
Найти как можно больше подряд идущих чисел, которые бы делились на одно и то же число, большее 1. Найти количество простых элементов последовательности идущих подряд
|
|
Диссидент
27714 / 17332 / 3810
Регистрация: 24.12.2010
Сообщений: 38,978
|
|
| 19.07.2021, 14:02 | |
|
dmitrii2000, находить НОД умеете? Двух чисел? Нескольких?
Добавлено через 1 минуту Старайтесь соблюдать правило 4.7
0
|
|
|
393 / 263 / 193
Регистрация: 02.05.2017
Сообщений: 1,003
|
||
| 19.07.2021, 18:49 | ||
|
dmitrii2000, вроде можно за n*log*log решить, если написать бинарный поиск по ответу + дерево отрезков на нод. А можно перебрать все простые числа до 1000, их около 100, и для каждого числа найти максимальный отрезок, в котором каждый элемент делится на это число. Потом выбрать наибольший и вывести. Это уровень ЕГЭ, вы справитесь. Нет, код я вам не отправлю, мне это неинтересно писать.
1
|
||
|
Диссидент
27714 / 17332 / 3810
Регистрация: 24.12.2010
Сообщений: 38,978
|
||
| 19.07.2021, 22:37 | ||
|
С вами полностью солидарен.
0
|
||
|
2 / 2 / 0
Регистрация: 03.05.2020
Сообщений: 202
|
|
| 20.07.2021, 13:38 [ТС] | |
|
Скиньте код пожалуйста
0
|
|
|
Диссидент
27714 / 17332 / 3810
Регистрация: 24.12.2010
Сообщений: 38,978
|
||
| 20.07.2021, 13:59 | ||
|
0
|
||
|
2 / 2 / 0
Регистрация: 03.05.2020
Сообщений: 202
|
||||||
| 20.07.2021, 14:22 [ТС] | ||||||
|
Помогите пожалуйста код не проходит по времени
0
|
||||||
|
Диссидент
27714 / 17332 / 3810
Регистрация: 24.12.2010
Сообщений: 38,978
|
||
| 20.07.2021, 16:55 | ||
|
Добавлено через 9 минут Код, похоже, рабочий. Сам писал? Но слишком лобовой. Тут потоньше надо... Добавлено через 2 часа 16 минут Один из путей оптимизации кодаЖ Во внешнем цикле пропускать a[i], взаимно простые с те, которое нарушило делимость.... Все равно от них ничего хорошего ждать не приходится...
0
|
||
|
Модератор
|
|
| 05.08.2021, 08:25 | |
|
Что то пришла в голову мысль:
1. в массиве искать НОД двух соседних чисел массива и тут же перезаписывать (заменять элемент на НОД) массив, который при этом уменьшится на 1 элемент. 2. операцию повторять пока все элементы массива не станут равны 1 или до сокращения длины массива до 1. 3. количество итераций и будет ответом. 4. для оптимизации пропускать элементы с 1, сокращать массив слева и справа при равенстве элементов 1.
1
|
|
|
Диссидент
27714 / 17332 / 3810
Регистрация: 24.12.2010
Сообщений: 38,978
|
|
| 05.08.2021, 12:23 | |
|
[quote="ФедосеевПавел;15650702"]Что то пришла в голову мысль[/quoto(e]Мысль интересная, но это, имхо, O(n2) как минимум
0
|
|
|
Модератор
|
|||
| 05.08.2021, 13:27 | |||
|
Да, похоже, у меня не лучший вариант. А других собственных пока и нет.
Согласен с LegionK - можно воспользоваться ограниченным диапазоном элементов массива
0
|
|||
|
Диссидент
27714 / 17332 / 3810
Регистрация: 24.12.2010
Сообщений: 38,978
|
|
| 05.08.2021, 14:55 | |
|
0
|
|
|
393 / 263 / 193
Регистрация: 02.05.2017
Сообщений: 1,003
|
||
| 16.08.2021, 18:20 | ||
|
Т.к если в массиве присутствует хороший отрезок длины k, то будут присутствовать и все отрезки длины 1,2,...k-1, (хотя бы как подотрезки этого подотрезка). Соответственно если обозначить функцию f(t) как "присутствует ли хороший отрезок длины t в массиве", то для значений t от 1 до n значения f(t) будут : 1, 1, 1, 1, 1....,1, 0, 0, 0, 0, 0...... Вот ту последнюю единицу нам и надо найти. Сделать это можно при помощи бинарного поиска. Всё что осталось - написать функцию f. То есть уметь проверять, есть ли у нас в массиве хороший подотрезок нужной длины. Пусть нам дано число k и нужно проверить, есть ли хороший отрезок длины k. Можно идти по массиву слева направо и для каждого i проверять, подходит ли нам отрезок i...i+k при помощи дерева отрезков на нод. Ну в целом всё. Для данной задачи это излишне и асимптотика будет n*log*log*log. Это >= n*1000, но это все равно на порядок-два меньше, чем n*n. Решается эта задача как я написал выше про простые числа. Не хотел вам отвечать потому что идея эта здесь ненужная и заметил я это просто так, но недавно увидел задачу сводящуюся к этой, а именно к вот этому методу (а не первому, потому что нету ограничения такого маленького на сами числа массива) и подумал, что вам, может быть, будет все же интересно. Вот задача https://codeforces.com/contest/1549/problem/D чтобы решение посмотреть в правом нижнем углу "разбор задач". Там предлагается вместо дерева отрезков использовать разреженную таблицу, чтобы от одного логарифма в произведении избавиться, но я эту структуру не знаю.
1
|
||
|
Диссидент
27714 / 17332 / 3810
Регистрация: 24.12.2010
Сообщений: 38,978
|
|
| 16.08.2021, 21:56 | |
|
LegionK, Если я вас правильно понял, основная идея, заключается в том, что вы ищите Хороший отрезок дли N, при неудаче, длины N/2, дальше N/4 или 3N/4. И так далее...
Или я не врубаюсь?
0
|
|
|
393 / 263 / 193
Регистрация: 02.05.2017
Сообщений: 1,003
|
|
| 17.08.2021, 02:10 | |
|
Байт, Да, как обычный бинарный поиск.
0
|
|
|
Вездепух
12925 / 6793 / 1819
Регистрация: 18.10.2014
Сообщений: 17,190
|
|||||||
| 17.08.2021, 05:31 | |||||||
0
|
|||||||
|
393 / 263 / 193
Регистрация: 02.05.2017
Сообщений: 1,003
|
|||||||
| 17.08.2021, 09:29 | |||||||
|
0
|
|||||||
|
Вездепух
12925 / 6793 / 1819
Регистрация: 18.10.2014
Сообщений: 17,190
|
||
| 17.08.2021, 17:56 | ||
|
Бинарный поиск производится по упорядоченной последовательности. Где здесь упорядоченная проследовательность? Упорядоченная проследовательность чего и как она упорядочена?
0
|
||
|
393 / 263 / 193
Регистрация: 02.05.2017
Сообщений: 1,003
|
||
| 17.08.2021, 18:02 | ||
|
0
|
||
| 17.08.2021, 18:07 | |
|
0
|
|
| 17.08.2021, 18:07 | |
|
Помогаю со студенческими работами здесь
20
Найти максимальное количество элементов последовательности, идущих подряд и являющихся простыми числами Даны натуральное число n, символы s1,...,sn. Выяснить,верно ли,что в последовательности s1,...,sn имеются пять идущих подряд букв е
Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
||||
|
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Рецензия / Мнение
Это мой обзор планшета X220 с точки зрения школьника.
Недавно я решила попытаться уменьшить свой. . .
|
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта
Симптом:
После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
|
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
|
Новый ноутбук
volvo 07.12.2025
Всем привет.
По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне:
Ryzen 5 7533HS
64 Gb DDR5
1Tb NVMe
16" Full HD Display
Win11 Pro
|
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
|
|
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
|
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов
На странице:
https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/
нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
|
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов.
. . .
|
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
|
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
|