Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > [ "Начинающим" ]
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 06.03.2010, 23:09
Asira Asira вне форума
Новичок
 
Регистрация: 11.12.2009
Сообщения: 76
Репутация: -26
По умолчанию Динамические массивы...

Даны два целочисленных массива. Можно ли в первом из них выбрать 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
Ответить с цитированием
  #2  
Старый 07.03.2010, 03:09
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,024
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

В алгоритме.
Нарисуй алгоритм на бумаге.

На самом деле у тебя будет фактически 3 вложенных цикла. Внешний перебирает N от длинны до 1. Второй - берет образец длинны n по первому массиву и третьий - ищет вхождение образца во второй массив.

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


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 19:40.


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2023

ВКонтакте   Facebook   Twitter