Форум программистов
 

Восстановите пароль или Зарегистрируйтесь на форуме, о проблемах и с заказом рекламы пишите сюда - alarforum@yandex.ru, проверяйте папку спам!

Вернуться   Форум программистов > IT форум > Помощь студентам
Регистрация

Восстановить пароль

Купить рекламу на форуме - 42 тыс руб за месяц

Ответ
 
Опции темы Поиск в этой теме
Старый 07.03.2010, 00:38   #1
Asira
Пользователь
 
Регистрация: 12.12.2009
Сообщений: 84
По умолчанию Динамический массив Делфи

Даны два целочисленных массива. Можно ли в первом из них выбрать N подряд идущих элементов, чтобы они шли подряд в той же последовательности во втором? Вывести эту последовательность. Создавать дополнительный массив, множество или другую структуру нельзя. Мой вариант. но он работает не правильно... точнее я не знаю как сделать чтобы выводилась последовательность именно из n элементов
a:0001001010
b: 1101000000 Вывод- совпадение - 0100 совпадение 0 совпадение 000 не выводит случаи - совпадение 01 совпадение 100 совпадение 010 Подскажите где искать ошибку?!
Код:
{$APPTYPE CONSOLE}

uses
  SysUtils;
procedure vvod(var a:array of byte;n:byte);
  var i:byte;
  begin
  for i:=0 to high(a) do a[i]:=random(5);
  end;
procedure vivod(a:array of byte);
  var i:byte;
  begin
  for i:=0 to high(a) do write(a[i],' ');
  writeln;
  end;
procedure Mogno(a,b:array of byte;n:byte);
  var i:byte;
  begin
  i:=0;
  while i<>n do
  begin
  if (a[i]=b[i]) and (a[i+1]=b[i+1]) then
  begin
  writeln('sovpadenie:');
  while a[i]=b[i] do
  begin
  write(a[i],' ');
  inc(i);
  end;
  writeln;
  end
  else
  inc(i);
  end;
end;
var a,b:array of byte;
     n:byte;
begin
  write('n= '); readln(n);
  setlength(a,n);
  setlength(b,n);
  randomize;
  vvod(a,n);
  vivod(a);
  vvod(b,n);
  vivod(b);
  Mogno(a,b,n);
  readln; end.
Asira вне форума Ответить с цитированием
Старый 07.03.2010, 02:32   #2
eoln
Старожил
 
Аватар для eoln
 
Регистрация: 26.04.2008
Сообщений: 2,645
По умолчанию

m - размерность массива
n - кол-во подряд идущих элементов
Выводятся всевозможные совпадения
Код:
procedure vvod(var a:array of byte);
var
  i:byte;
begin
  for i:=0 to high(a) do a[i]:=random(2);
end;

procedure vivod(a:array of byte);
var
  i:byte;
begin
  for i:=0 to high(a) do write(a[i],' ');
  writeln;
end;

procedure print(a: array of byte; p, n: byte);
var
  i: byte;
begin
  for i := p to p + n - 1 do write(a[i], ' ');
  writeln
end;

procedure Mogno(a,b:array of byte;n:byte);
var
  i, j, k: byte;
  bool: boolean;
begin
  for i := 0 to high(a) - n + 1 do
  for k := 0 to high(b) - n + 1 do
  begin
    bool := true;
    for j := 0 to n - 1 do
      if a[j + i] <> b[j + k] then bool := false;
    if bool then print(a, i, n)
  end
end;

var
  a, b: array of byte;
  n, m: byte;
begin
  write('m = ');
  readln(m);
  write('n = ');
  readln(n);
  setlength(a, m);
  setlength(b, m);
  randomize;
  vvod(a);
  vivod(a);
  vvod(b);
  vivod(b);
  Mogno(a,b,n);
  readln
end.
eoln вне форума Ответить с цитированием
Ответ


Купить рекламу на форуме - 42 тыс руб за месяц



Похожие темы
Тема Автор Раздел Ответов Последнее сообщение
Динамический массив! Mikhail91 Общие вопросы C/C++ 9 14.02.2010 14:45
Динамический массив Vito89 Общие вопросы Delphi 3 20.10.2009 01:20
Динамический массив Ivin Мультимедиа в Delphi 14 27.02.2009 23:22
динамический массив Diller Помощь студентам 48 07.10.2007 16:43
Динамический массив Mickle Общие вопросы Delphi 8 19.06.2007 06:45