Форум программистов, компьютерный форум, киберфорум
Python: Решение задач
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.60/25: Рейтинг темы: голосов - 25, средняя оценка - 4.60
0 / 0 / 0
Регистрация: 21.11.2021
Сообщений: 3

Найдите количество троек чисел

21.11.2021, 13:23. Показов 5654. Ответов 9

Студворк — интернет-сервис помощи студентам
Вам дан массив из целых неотрицательных чисел a1, a2, . . . an. Найдите количество троек чисел 1 <= i < j < k <= n, таких что (a[i] ⊕a[j]) < (a[j] ⊕a[k]), где ⊕ — это операция побитового исключающего ИЛИ (XOR). Ограничение по времени 2 секунды, где n может быть огромным
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
21.11.2021, 13:23
Ответы с готовыми решениями:

Определите количество уникальных троек чисел
Последовательность чисел вводится с клавиатуры.Тройка идущих подряд чисел последовательности называется уникальной, если только второе из...

Сформировать массив из случайных целых чисел от 0 до 9 , в котором количество единиц от 3 до 5 и двоек больше троек
Я новичок, помогите решить задачу. Желательно так, чтобы была понятна. Сформировать массив из случайных целых чисел от 0 до 9 , в котором...

Количество троек элементов последовательности, хотя бы одно число из которых делится на 5, и сумму минимальных чисел
В файле 17-10.txt содержится последовательность целых чисел. Элементы последовательности могут принимать значения от 0 до 10000...

9
1956 / 874 / 352
Регистрация: 05.09.2021
Сообщений: 1,387
21.11.2021, 14:43
SomeHackPython, Решил "в лоб".
Python
1
2
3
4
5
6
7
8
a = list(range(100))
c = 0
for i in range(len(a) - 2):
    for j in range(i + 1, len(a) - 1):
        for k in range(j + 1, len(a)):
            if a[i] ^ a[j] < a[j] ^ a[k]:
                c += 1
print(c)
0
0 / 0 / 0
Регистрация: 21.11.2021
Сообщений: 3
21.11.2021, 14:56  [ТС]
По времени не проходит. Я так же написал
0
1956 / 874 / 352
Регистрация: 05.09.2021
Сообщений: 1,387
21.11.2021, 15:40
SomeHackPython, Можно ускорить за счет кеширования.
Python
1
2
3
4
5
6
7
8
9
a = list(range(100))
b = [[a[i] ^ a[j] for i in range(0, n)] for j in range(0, n)]
c = 0
for i in range(len(a) - 2):
    for j in range(i + 1, len(a) - 1):
        for k in range(j + 1, len(a)):
            if b[i][j] < b[j][k]:
                c += 1
print(c)
Получилось примерно в два раза быстрее. Можно еще ускорить, т.к. в данном случае присутствует избыточный расчет.
0
Status 418
Эксперт Python
4584 / 2350 / 601
Регистрация: 26.11.2017
Сообщений: 5,262
Записей в блоге: 3
21.11.2021, 16:15
anton78spb, и какая сложность Вашего решения?

Добавлено через 36 секунд
SomeHackPython, ограничения какие на входные данные?

Добавлено через 3 минуты
Цитата Сообщение от SomeHackPython Посмотреть сообщение
где n может быть огромным
огромным это сколько?
0
1956 / 874 / 352
Регистрация: 05.09.2021
Сообщений: 1,387
21.11.2021, 16:20
eaa, Похоже на O(n^3).
0
Status 418
Эксперт Python
4584 / 2350 / 601
Регистрация: 26.11.2017
Сообщений: 5,262
Записей в блоге: 3
21.11.2021, 16:24
тут решение похоже O(n*logn)

Добавлено через 1 минуту
SomeHackPython, примеры есть входных/выходных данных?
0
1956 / 874 / 352
Регистрация: 05.09.2021
Сообщений: 1,387
21.11.2021, 16:49
eaa, Т.к. значений у нас n, и в сравнении участвуют три числа, то кол-во сравнений получается примерно n^3. Т.к. у нас i < j < k, то это кол-во уменьшается в двое. Но все равно это получается порядка n^3. Пока не приходит в голову, как это можно уменьшить хотя бы до n^2, не говоря уже о n*log(n).

Добавлено через 4 минуты
eaa, Сложность создания "кэшированной" матрицы с результатами (a[i] xor a[j]), порядка n^2. Возможно и последующую обработку можно как-то сократить до этого же порядка (n^2).
0
Status 418
Эксперт Python
4584 / 2350 / 601
Регистрация: 26.11.2017
Сообщений: 5,262
Записей в блоге: 3
21.11.2021, 17:08
ошибся, не O(n*logn), а O(n*log(max(a)). интересно какие числа в a, похоже положительные только. 32 или 64 бита.
0
0 / 0 / 0
Регистрация: 21.11.2021
Сообщений: 3
21.11.2021, 17:25  [ТС]
огромный n. Точно не помню, но вроде 10^5
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
21.11.2021, 17:25
Помогаю со студенческими работами здесь

Подсчитайте в последовательности количество единиц, количество двоек, количество троек
Задача на питоне. Вот условие: На вход программе подается последовательность чисел от 1 до 9, заканчивающаяся нулем. Всего будет...

Найдите количество таких чисел и их сумму
Рассмотрим множество целых чисел, принадлежащих числовому отрезку , в записи которых используются только чётные цифры. Найдите количество...

Найдите в дереве сумму и количество чисел меньше 25
Найдите в дереве сумму и количество чисел меньше 25 нужен код

Найдите количество и среднее арифметическое натуральных четырехзначных чисел
Найдите количество и среднее арифметическое натуральных четырехзначных чисел, в которых первая цифра равна третьей, а вторая четвертой...

Найдите количество и среднее арифметическое всех четырехзначных положительных целых чисел
Найдите количество и среднее арифметическое всех четырехзначных положительных целых чисел. Действительным считается число, в котором...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
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. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru