Я работаю над проблемой Python, где мне нужно проверить, содержит ли несортированный массив дубликаты на указанном расстоянии k. В частности, мне нужно вернуть True, если какое-либо значение появляется более одного раза в пределах k индексов, в противном случае верните False.
Например, если задан массив [1, 2, 3, 1] и k = 3, ожидаемый результат будет истинным, поскольку элемент 1 снова появляется в диапазоне 3-х индексов. Если бы k было равно 2, ожидаемый результат был бы False.
Я знаю, что есть несколько способов решить эту проблему, но мне нужно эффективное решение.
Как я могу решить эту проблему, используя скользящее окно или другой оптимальный подход?
Ограничения:
Массив может содержать до 10^5 элементов.
k всегда меньше длины массива.
Любые советы или решения буду очень признателен!
Я ожидал, что подход скользящего окна позволит эффективно идентифицировать дубликаты на указанном расстоянии с временной сложностью
𝑂
(
𝑛
)
O(n), где
𝑛
n — размер массива. Набор будет отслеживать текущие элементы окна, и дубликаты будут обнаруживаться в пределах разрешенного диапазона.
Подробнее здесь: https://stackoverflow.com/questions/791 ... ecific-dis
Как я могу эффективно определить, содержит ли массив дубликаты на определенном расстоянии, используя Python? ⇐ Python
Программы на Python
1731665248
Anonymous
Я работаю над проблемой Python, где мне нужно проверить, содержит ли несортированный массив дубликаты на указанном расстоянии k. В частности, мне нужно вернуть True, если какое-либо значение появляется более одного раза в пределах k индексов, в противном случае верните False.
Например, если задан массив [1, 2, 3, 1] и k = 3, ожидаемый результат будет истинным, поскольку элемент 1 снова появляется в диапазоне 3-х индексов. Если бы k было равно 2, ожидаемый результат был бы False.
Я знаю, что есть несколько способов решить эту проблему, но мне нужно эффективное решение.
Как я могу решить эту проблему, используя скользящее окно или другой оптимальный подход?
Ограничения:
Массив может содержать до 10^5 элементов.
k всегда меньше длины массива.
Любые советы или решения буду очень признателен!
Я ожидал, что подход скользящего окна позволит эффективно идентифицировать дубликаты на указанном расстоянии с временной сложностью
𝑂
(
𝑛
)
O(n), где
𝑛
n — размер массива. Набор будет отслеживать текущие элементы окна, и дубликаты будут обнаруживаться в пределах разрешенного диапазона.
Подробнее здесь: [url]https://stackoverflow.com/questions/79191908/how-can-i-efficiently-find-if-an-array-contains-duplicates-within-a-specific-dis[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия