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

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

21.11.2021, 13:23. Показов 5710. Ответов 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
Ответ Создать тему
Новые блоги и статьи
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
Использование значений реквизитов справочника в документе, с определенными условиями и правами
Maks 07.04.2026
1. Контроль срока действия договора Алгоритм из решения ниже реализован на примере нетипового документа "ЗаявкаНаРаботу", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru