|
7 / 7 / 7
Регистрация: 20.06.2016
Сообщений: 72
|
|||||||||||
Как ускорить программу?10.11.2017, 23:12. Показов 1783. Ответов 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
Как ускорить программу Как ускорить программу? Как ускорить программу? Как ускорить программу Как можно ускорить программу? Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
| Опции темы | |
|
|
Новые блоги и статьи
|
|||
|
Отчёт о затраченных материалах за определенный период с макетом печатной формы
Maks 21.04.2026
Отчёт из решения ниже размещён в конфигурации КА2.
Задача: разработка отчёта по затраченным материалам за определённый период, с возможностью вывода печатной формы отчёта с шапкой и подвалом.
В. . .
|
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2.
Задача: отобразить спецтехнику, которая на данный момент находится в ремонте.
Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
|
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
|
Запрет удаления строк ТЧ документа при определённом условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
|
|
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут
Суть:
- Группа наркоманов из 10 человек.
- Только один инфицирован ВИЧ.
- Колются одной иглой.
- Колются раз в день.
- Колются последовательно через. . .
|
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
|
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
|
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . .
а удачный момент так и не приходит.
|