С Новым годом! Форум программистов, компьютерный форум, киберфорум
Pascal (Паскаль)
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.93/29: Рейтинг темы: голосов - 29, средняя оценка - 4.93
0 / 0 / 0
Регистрация: 01.12.2015
Сообщений: 120

Приближенный двоичный поиск

07.05.2016, 12:03. Показов 5486. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Помогите пожалуйста решить задачую Заранее спасибо!

Реализуйте алгоритм приближенного бинарного поиска.

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

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

Примеры
входные данные
5 5
1 3 5 7 9
2 4 8 1 6
выходные данные
1
3
7
1
5
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
07.05.2016, 12:03
Ответы с готовыми решениями:

Двоичный поиск
Например: nx:=0 l:=1; r:=n; while r&gt;=l do begin c:=(r+l) div 2; ifx = a then begin nx:=c; r:=l-1;(break; )

Двоичный поиск в массиве чисел
Дан массив чисел const A: array of integer = (-3, 2, 4, 15, 21, 48, 55, 96); Выполните шаг за шагом алгоритм двоичного поиска числа 3 в...

Двоичный поиск в трехмерном массиве
В трехмерном массиве найти заданный Х, использовав алгоритм двоичного поиска, который находит самый левый из совпадающих элементов.

1
Эксперт Pascal/Delphi
6812 / 4568 / 4820
Регистрация: 05.06.2014
Сообщений: 22,434
08.05.2016, 20:21
Лучший ответ Сообщение было отмечено Derzky как решение

Решение

(С) Найдено в Интернете

Pascal
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
program project12;
var
  a,b:array[1 .. 1000] of integer;
  i,n,l,r,m,k,c:integer;
begin
  readln(n,k);
  for i:=1 to n do
    readln(a[i]);
  for i:=1 to k do
    readln(b[i]);
  for i:=1 to k do
    begin
      l:=1;
      r:=n;
      while l<>r do
        begin
          m:=(l+r) div 2;
          if (b[i]<=a[m]) then
            r:=m
          else
            l:=m+1;
        end;
  if(a[r-1]-b[i]<0) then
    c:=(a[r-1]-b[i])*(-1)
  else
    c:=a[r-1]-b[i];
  if (r<>1) and ((a[r]-b[i]<c) or(a[r]-b[i]=0)and(c<>0))or(r=1)then
    writeln(a[r])
  else
    writeln(a[r-1]);
  end;
  readln
end.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
08.05.2016, 20:21
Помогаю со студенческими работами здесь

Одномерный массив. Двоичный поиск елемента
Пожалуйста, помогите найти ошибку и ее решение) Задано массив X. Задано целое число а. Если в массиве х есть елемент, значение...

Приближенный бинарный поиск
В FoxPro есть команда SET NEAR ON, по которой указатель ставится на ближайшее к заказанному числу значение. Допустим, есть ряд (1, 3, 4, 7,...

Двоичный поиск
Здраствуйте. Можно ли как то сделать так, чтобы при двоичном поиске выводились все совпадения, а то показывается только 1. procedure...

Двоичный поиск
Задание: Реализуйте алгоритм бинарного поиска. Входные данные: В первой строке входных данных содержатся натуральные числа N и K...

Двоичный(бинарный) поиск
Доброго времени суток,коллеги =) Возникла у меня проблема - написал программу,реализующую двоичный поиск,а препод говорит,что неправильно))...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Модель микоризы: классовый агентный подход 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 законам Кирхгофа и решает её. Последовательность действий:. . .
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
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? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru