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

Delphi Sources



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

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 18.10.2011, 21:54
Serioja Serioja вне форума
Прохожий
 
Регистрация: 18.10.2011
Сообщения: 3
Репутация: 10
Сообщение Помогите с массивами!

Задан массив целых чисел,X(n) n<=300. Разработать программу, которая находит в этом массиве и печатает длинный цепочка чисел, упорядоченных по возрастанию!!!

Помогите пожалуйста!!
Ответить с цитированием
  #2  
Старый 18.10.2011, 21:59
freedomman freedomman вне форума
Новичок
 
Регистрация: 12.10.2011
Сообщения: 51
Репутация: 10
По умолчанию

недопонял условие.... надо найти в массиве упорядоченную цепочку и вывести ее???

Последний раз редактировалось freedomman, 18.10.2011 в 22:04.
Ответить с цитированием
  #3  
Старый 18.10.2011, 22:02
Serioja Serioja вне форума
Прохожий
 
Регистрация: 18.10.2011
Сообщения: 3
Репутация: 10
По умолчанию

да там надо найти самою длинною цепочку и вывести ее!! но не в консольном режими!

Последний раз редактировалось Serioja, 18.10.2011 в 22:30.
Ответить с цитированием
  #4  
Старый 19.10.2011, 18:44
elluminate elluminate вне форума
Прохожий
 
Регистрация: 09.11.2010
Сообщения: 7
Репутация: 10
По умолчанию

Можно в цикле проходить массив и записывать в др. массив цепочку возрастающих, считать их длину. Если длина следующей цепочки больше, то индекс второго массива опять на 1 устанавливать и заново записывать. И после окончания цикла второй массив вывести
Ответить с цитированием
  #5  
Старый 20.10.2011, 06:38
kledno kledno вне форума
Прохожий
 
Регистрация: 14.10.2011
Сообщения: 1
Репутация: 10
По умолчанию

Попробуй вот так, имей ввиду, практически не тестировал но работать должно, поправишь если что:
Код:
var mas : array[0..299] of integer;
i, j, kol, max : integer;
str, stroka : string;
begin
kol := StrToINT(Edit1.Text) - 1;
Randomize;
{заполняем массив случайными числами}
for i := 0 to kol do
begin
mas[i] := Random(100) + 1;
str := str + IntToStr(mas[i]) + ', ';
end;
Label2.Caption := str;
{обнуляем счетчики}
i := 0;
j := 0;
max := 0;
str := '';
stroka := '';
{Обработка массива mas}
while i<=kol do
  begin
    if kol = 1 then stroka := 'Последовательность не найдена' else
      begin
        if mas[i]<mas[i+1] then
          begin
          j := j + 1;
          str := str + IntToStr(mas[i]);
          end;
        if (mas[i]>=mas[i+1]) and (j = 0) then str := '';
        if (mas[i]>=mas[i+1]) and (j<>0) then
            begin
            str := str + IntToStr(mas[i]);
            if  j > max then
              begin
              max := j;
              stroka := str;
              end;
              j:=0;
              str := '';
            end;
        if (i = kol) and (j>max)
        then begin
              str:=str+ IntToStr(mas[i]);
              stroka := str;
              end;
              if (i=kol) and (j=0) then stroka := 'не найдено';
              i := i + 1;

      end;

  end;
  Label1.Caption := stroka;

      end;


end.
Ответить с цитированием
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

Соглашения

Прочее

 

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