С Новым годом! Форум программистов, компьютерный форум, киберфорум
Python для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.55/166: Рейтинг темы: голосов - 166, средняя оценка - 4.55
2 / 2 / 0
Регистрация: 15.11.2015
Сообщений: 12

Левый и правый двоичный поиск

15.11.2015, 20:07. Показов 37058. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Дано два списка чисел, числа в первом списке упорядочены по неубыванию. Для каждого числа из второго списка определите номер первого и последнего появления этого числа в первом списке.

В первой строке входных данных записано два числа N и M (1 ≤ N, M ≤ 20000 ). Во второй строке записано N упорядоченных по неубыванию целых чисел — элементы первого списка. В третьей строке записаны M целых неотрицательных чисел - элементы второго списка. Все числа в списках - целые 32-битные знаковые.

Программа должна вывести M строчек. Для каждого числа из второго списка нужно вывести номер его первого и последнего вхождения в первый список. Нумерация начинается с единицы. Если число не входит в первый список, нужно вывести одно число 0.
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
15.11.2015, 20:07
Ответы с готовыми решениями:

Левый и правый двоичный поиск
n, m = map(int, input().split()) arr1 = arr2 = for x in arr2: left = 0 right = n - 1 g = arr1.count(x) ...

Левый и правый двоичный поиск
Дано два списка чисел, числа в первом списке упорядочены по неубыванию. Для каждого числа из второго списка определите номер первого и...

Левый и правый двоичный поиск
Дано два списка чисел, числа в первом списке упорядочены по неубыванию. Для каждого числа из второго списка определите номер первого и...

7
Эксперт NIX
 Аватар для Marinero
2796 / 2039 / 682
Регистрация: 02.03.2015
Сообщений: 6,509
16.11.2015, 02:18
Лучший ответ Сообщение было отмечено Olya652 как решение

Решение

Python
1
2
3
4
5
6
7
8
9
10
11
12
import bisect
 
N, M = input().split()
list1 = (int(input()) for _ in range(int(N)))
list2 = (int(input()) for _ in range(int(M)))
 
for x in list2:
    i = bisect.bisect_left(list1, x)
    if list1[i] == x:
        print(i + 1, bisect.bisect(list1, x, i))
    else:
        print(0)
0
1 / 1 / 0
Регистрация: 12.07.2020
Сообщений: 42
16.07.2020, 22:35
Marinero, ваша программа выдаёт ошибку
0
Модератор
Эксперт Python
 Аватар для Fudthhh
2695 / 1601 / 513
Регистрация: 21.02.2017
Сообщений: 4,210
Записей в блоге: 1
17.07.2020, 10:16
Russia_top, подсказка: списки так не инициализируют.
0
2 / 2 / 0
Регистрация: 24.05.2020
Сообщений: 4
18.07.2020, 10:21
Решение:
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
import bisect
 
N, M = map(int,input().split())
list1 = [int(x) for x in input().split()]
list2 = [int(x) for x in input().split()]
 
for x in list2:
    i = bisect.bisect_left(list1, x)
    if i >= N:
        print(0)
        continue
    if list1[i] == x:
        print(i + 1, bisect.bisect(list1, x, i))
    else:
        print(0)
2
1 / 1 / 0
Регистрация: 12.07.2020
Сообщений: 42
18.07.2020, 14:32
Цитата Сообщение от StarlinkOK Посмотреть сообщение
Решение:
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
import bisect
 
N, M = map(int,input().split())
list1 = [int(x) for x in input().split()]
list2 = [int(x) for x in input().split()]
 
for x in list2:
    i = bisect.bisect_left(list1, x)
    if i >= N:
        print(0)
        continue
    if list1[i] == x:
        print(i + 1, bisect.bisect(list1, x, i))
    else:
        print(0)
Спасибо! Решение верное!
0
0 / 0 / 0
Регистрация: 17.07.2022
Сообщений: 13
17.07.2022, 16:03
А почему у вас в 13 строке в коде:
print(i + 1, bisect.bisect(list1, x, i))
^
вот здесь указана i для чего она нужна, ведь без нее код выполняет тоже самое
0
0 / 0 / 0
Регистрация: 31.03.2023
Сообщений: 1
31.03.2023, 08:38
Python
1
2
3
4
5
6
7
8
N, M = map(int,input().split())
list1 = [int(x) for x in input().split()]
list2 = [int(x) for x in input().split()]
 
for x in list2:
    if x in list1:
        print (list1.index(x)+1, list1.count(x)+list1.index(x))
    else: print(0)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
31.03.2023, 08:38
Помогаю со студенческими работами здесь

Левый и правый двоичный поиск
Дано два списка чисел, числа в первом списке упорядочены по неубыванию. Для каждого числа из второго списка определите номер первого и...

Левый и правый двоичный поиск
Помогите пожалуйста решить задачую Заранее спасибо! Дано два списка чисел, числа в первом списке упорядочены по неубыванию. Для каждого...

Левый и правый двоичный поиск
Помогите, пожалуйста, не проходит 1 тест, не понимаю из-за чего :( Дано два списка чисел, числа в первом списке упорядочены по...

Кошки двигаются в левый верхний, правый нижний, левый нижний, правый верхний углы их области обитания со скоростью V
Кошки двигаются в левый верхний, правый нижний, левый нижний, правый верхний углы их области обитания со скоростью V, после чего этот...

Левый и правый блок
Пишу главную страницу сайта. Возникла проблема. Я сделал две колонки через float, одну левую, другую правую. В левой колонке пытаюсь...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути
Programma_Boinc 01.01.2026
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути Сочетание глобально распределённой вычислительной мощности и инновационных. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru