IPB
ЛогинПароль:

> Прочтите прежде чем задавать вопрос!

1. Заголовок темы должен быть информативным. В противном случае тема удаляется ...
2. Все тексты программ должны помещаться в теги [code=pas] ... [/code].
3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали!
4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора).
5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM!
6. Одна тема - один вопрос (задача)
7. Проверяйте программы перед тем, как разместить их на форуме!!!
8. Спрашивайте и отвечайте четко и по существу!!!

> Бинарный (двоичный) поиск, только для отсортированного массива
klem4
сообщение 24.02.2005 18:35
Сообщение #1


Perl. Just code it!
******

Группа: Модераторы
Сообщений: 4 100
Пол: Мужской
Реальное имя: Андрей

Репутация: -  44  +


value - искомое значение
right и left - сдвигающиеся границы массива.


Код

procedure bin_s;
var
  value:integer{array type};
  x:array[1..n] of integer;
  i,nn,nfind,right,left:integer;
begin
  writeln('value=');readln(value);
  left:=1;
  right:=n;
  while ((right-left)>1) do
   begin
      nn:=(right+left) div 2;
      if value<=x[nn] then
       right:=nn
        else left:=nn;
   end;
   if value=x[left] then
    nfind:=left
     else if value=x[right] then
      nfind:=right;
  writeln('nfind=',nfind);
  readln;
end;


Скорость :
1000 элементов - 10 итераций цикла.

Процедура не срабатывает с такими исходными данными (возвращается результат "nfind = 2"):
const
n = 20;
x: array[1 .. n] of integer =
( 4, 5, 6, 15, 18, 21, 28, 32, 34, 38,
43, 44, 49, 50, 59, 60, 63, 73, 77, 85);
{ Значение для поиска: value = 34 }

Volvo


--------------------
perl -e 'print for (map{chr(hex)}("4861707079204E6577205965617221"=~/(.{2})/g)), "\n";'
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
 
 Ответить  Открыть новую тему 
Ответов
volvo
сообщение 27.02.2005 20:01
Сообщение #2


Гость






Проверь вот это:
Код
Type
 TType = Integer;

Function bin_search(Var x: Array Of TType;
        Const n: Integer; Value: TType): Integer;
Var
 nn, nFind, Right, Left: Integer;
Begin
 Left := 0; Right := Pred(n);
 While (Right - Left) > 1 Do
   Begin
     nn := (Right + Left) div 2;
     If Value <= x[nn] Then Right := nn
     Else Left := nn
   End;

 If Value = x[Left] Then nFind := Left
 Else
   If Value = x[Right] Then nFind := Right
   Else nFind := -2;

 bin_search := nFind + 1;
End;


Const
 n_1 = 20;
 x: array[1 .. n_1] of TType =
   ( 4,  5,  6, 15, 18, 21, 28, 32, 34, 38,
    43, 44, 49, 50, 59, 60, 63, 73, 77, 85);

 n_2 = 25;
 x1: array[1 .. n_2] of TType =
   ( 4,  5,  6, 15, 18, 21, 28, 32, 34, 38,
    43, 44, 49, 50, 59, 60, 63, 73, 77, 85,
    86, 87, 88, 89, 90);

 n_3 = 30;
 x2: array[1 .. n_3] of TType =
   ( 4,  5,  6, 15, 18, 21, 28, 32, 34, 38,
    43, 44, 49, 50, 59, 60, 63, 73, 77, 85,
    86, 87, 88, 89, 90, 91, 92, 93, 94, 95);

var
 i: integer;

begin
 writeln( bin_search(x, n_1, 18) );
 writeln( bin_search(x1, n_2, 38) );
 writeln( bin_search(x2, n_3, 94) );
end.
 К началу страницы 
+ Ответить 

Сообщений в этой теме


 Ответить  Открыть новую тему 
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 



- Текстовая версия 20.07.2025 5:32
Хостинг предоставлен компанией "Веб Сервис Центр" при поддержке компании "ДокЛаб"