|
7 / 7 / 7
Регистрация: 20.06.2016
Сообщений: 72
|
|||||||||||
Как ускорить программу?10.11.2017, 23:12. Показов 1742. Ответов 12
Здравствуйте, такая задача:
Страна состоит из n городов, которые расположены на оси. Координата i-го из городов равна xi. Выведите количество пар городов, между которыми расстояние составляет ровно d. Входные данные В первой строке записаны два целых числа n, d (2 ≤ n ≤ 10**5, 1 ≤ d ≤ 10**9). Вторая строка содержит координаты n городов — последовательность целых чисел x1, x2, ..., xn ( - 10**9 ≤ xi ≤ 10**9). Все xi — различны. Выходные данные Выведите искомое количество пар городов. Пары, отличающиеся только порядком городов, следует считать одной и той же парой. Вот мое решение:
Добавлено через 41 минуту Стало быстрее, но все равно недостаточно быстро.
0
|
|||||||||||
| 10.11.2017, 23:12 | |
|
Ответы с готовыми решениями:
12
Как ускорить программу Как ускорить программу |
|
440 / 432 / 159
Регистрация: 21.05.2016
Сообщений: 1,338
|
||||||
| 11.11.2017, 00:43 | ||||||
0
|
||||||
|
7 / 7 / 7
Регистрация: 20.06.2016
Сообщений: 72
|
|
| 11.11.2017, 00:54 [ТС] | |
|
Сложность вашего решения N**2. Оно уже при 1000 будет выполняться очень долго. А входные данные до 10**9
0
|
|
|
440 / 432 / 159
Регистрация: 21.05.2016
Сообщений: 1,338
|
||
| 11.11.2017, 01:00 | ||
Для поиска индекса необходимо пройти весь списокУ моего решения сложность O(n log n)
0
|
||
|
7 / 7 / 7
Регистрация: 20.06.2016
Сообщений: 72
|
|
| 11.11.2017, 01:06 [ТС] | |
|
Откуда тут log n? У вас два цикла, которые зависят от n. Тут даже не используется бинарный поиск числа. И решение за n log n не проходит все тесты. У вас по сути перебор всех возможных вариантов.
0
|
|
|
440 / 432 / 159
Регистрация: 21.05.2016
Сообщений: 1,338
|
||
| 11.11.2017, 01:24 | ||
|
Добавлено через 15 минут Хотя да, вру. Если брать хучший случай, то получится n * n/2 итераций
0
|
||
|
7 / 7 / 7
Регистрация: 20.06.2016
Сообщений: 72
|
|
| 11.11.2017, 01:26 [ТС] | |
|
Почему вы решили, что list.index ищет элементы простым перебором, а не методом двоичного поиска например? В любом случае, "внутренний" поиск самого питона быстрее, чем тот же поиск через циклы. Так как язык интерпретируемый, и не очень быстрый.
0
|
|
|
440 / 432 / 159
Регистрация: 21.05.2016
Сообщений: 1,338
|
||
| 11.11.2017, 01:37 | ||
|
Добавлено через 3 минуты Вот, кстати. Замените index на двоичный поиск, получите n log n
0
|
||
|
7 / 7 / 7
Регистрация: 20.06.2016
Сообщений: 72
|
||||||
| 11.11.2017, 01:44 [ТС] | ||||||
|
Эта программа работает медленней той, что я написал сначала. Это n log n.
0
|
||||||
|
440 / 432 / 159
Регистрация: 21.05.2016
Сообщений: 1,338
|
|
| 11.11.2017, 02:25 | |
|
эта быстрее работает на больших значениях n
Добавлено через 32 минуты Тут сортировка сама по себе дает n log n. Линейно эту задачу не решить
0
|
|
|
7 / 7 / 7
Регистрация: 20.06.2016
Сообщений: 72
|
|
| 11.11.2017, 13:17 [ТС] | |
|
Сортировать можно за log n. Цикл работает за n. Бинарный поиск работает за log n. Получается O(n log log n).
0
|
|
|
440 / 432 / 159
Регистрация: 21.05.2016
Сообщений: 1,338
|
|
| 11.11.2017, 18:46 | |
|
0
|
|
|
7 / 7 / 7
Регистрация: 20.06.2016
Сообщений: 72
|
|
| 11.11.2017, 21:28 [ТС] | |
|
Ошибся. Время работы сортировки слиянием O(n log n)
0
|
|
| 11.11.2017, 21:28 | |
|
Помогаю со студенческими работами здесь
13
Как ускорить программу Как ускорить программу? Как ускорить программу? Как ускорить программу Как можно ускорить программу? Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования.
Часть библиотеки BedvitCOM
Использованы. . .
|
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога
SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
|
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога
SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
|
влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
|
|
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога
SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
|
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога
Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip"
Извлеките архив и вы увидите. . .
|
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога
Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д.
Сборка примера
Скачайте. . .
|
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога
Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
|