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

Ближайшее число

28.07.2021, 15:35. Показов 3379. Ответов 3

Студворк — интернет-сервис помощи студентам
Для каждого из K чисел найдите ближайшее к нему число в отсортированном массиве.

Входные данные

В первой строке входных данных содержатся числа N и K (0<N,K<100001). Во второй строке задаются N чисел первого массива, отсортированного по неубыванию, а в третьей строке — K чисел второго массива. Каждое число в обоих массивах по модулю не превосходит 2⋅109.

Выходные данные

Для каждого из K чисел выведите в отдельную строку число из первого массива, наиболее близкое к данному. Если таких несколько, выведите меньшее из них.

Ограничение: работа программы не более 3 сек.
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
N, K = map(int, input().split())
P = [int(i) for i in input().split()]
V = list(map(int, input().split()))
a = []
 
 
for i in range(len(a)):
    if a[i] < n:
        find_num = -find_num
    else:
        find_num = find_num + 0
    if a[i] >= n and a[i] - n <= find_num - n:
        find_num = a[i]
    elif a[i] <= n and find_num - n <= a[i] - n:
        find_num = a[i]
 
 
print(P)
Можете подсказать, какие ошибки я допустил?
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
28.07.2021, 15:35
Ответы с готовыми решениями:

Найти ближайшее число
Ваша программа читает со стандартного ввода целое число n. Затем читает число m. n показывает, сколько ещё целых чисел будет вводиться...

Вывести ближайшее к числу N совершенное число
Есть код, который выводит совершенные числа на промежутке. Нужно сделать так, чтобы он выводил только ближайшее совершенное число, а не все...

Найти число, ближайшее к заданному, в этом же десятке
Найти число, ближайшее к заданному, в этом же десятке. Если число 9, то 8, никак не 10. Если число 45 - 44 или 46. Если 30 - 31, но...

3
Эксперт Python
8848 / 4500 / 1864
Регистрация: 27.03.2020
Сообщений: 7,315
28.07.2021, 17:45
psih23,
Можете подсказать, какие ошибки я допустил?
После 4-го оператора всё остальное...
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
from bisect import bisect_left
n, k = map(int, input().split())
num = list(map(int, input().split()))
que = list(map(int, input().split()))
for d in que:
    ind = bisect_left(num, d)
    if ind == 0:
        print(num[ind])
    elif ind == n:
        print(num[ind-1])
    else:
        print(num[ind] 
            if num[ind] - d < d - num[ind-1]
             else num[ind-1])
0
28.07.2021, 19:32

Не по теме:

Gdez, изюм из булки...

0
Эксперт Python
8848 / 4500 / 1864
Регистрация: 27.03.2020
Сообщений: 7,315
28.07.2021, 20:25
Лучший ответ Сообщение было отмечено Catstail как решение

Решение

Catstail, хорошо, согласен
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
#from bisect import bisect_left
 
def bin_search(a, x, n):
    
    L = -1
    R = n    
    
    while R - L > 1:
        
        mid = (R + L) // 2
        
        if a[mid] < x:
            L = mid
        else:
            R = mid
            
    return L
    
n, k = map(int, input().split())
num = list(map(int, input().split()))
que = list(map(int, input().split()))
for d in que:
    #ind = bisect_left(num, d)
    
    ind = bin_search(num, d, n)
 
    if ind == -1:
        print(num[0])
    elif ind == n:
        print(num[ind-1])
    else:
        print(num[ind] 
            if num[ind] - d < d - num[ind-1]
             else num[ind-1])

Не по теме:

по бинарному поиску много тем уже... Хотелось по другому...

1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
28.07.2021, 20:25
Помогаю со студенческими работами здесь

Найти ближайшее простое число к заданному с клавиатуры числу P
Найти ближайшее простое число к заданному с клавиатуры числу P.

Определить, есть ли в массиве Z из 10 значений заданное число Х, и если нет, то найти ближайшее к нему
Часть задачи сделать смог, а вот найти ближайшее число к любому заданному не получается.... Определить, есть ли в массиве Z из 10...

Найдите ближайшее большее число m такое, что сумма его цифр была строго больше суммы цифр числа n
Решите задачу одним циклом for, допускается применение условных операторов. Задано пятизначное число от n (10000≤n&lt;99999). Найдите...

Ближайшее простое
Напишите программу, которая находит ближайшее к заданному натуральному N простое число. пример тест 10 ответ 11 тест 12 ...

Найти ближайшее к заданному значение
Привет! Есть такая задача: Find the nearest value to the given one. You are given a list of values as set form and a value for...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и источниками (напряжения, ЭДС и тока). Найти токи и напряжения во всех элементах. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru