• Добро пожаловать на компьютерный форум Tehnari.ru. Здесь разбираемся с проблемами ПК и ноутбуков: Windows, драйверы, «железо», сборка и апгрейд, софт и безопасность. Форум работает много лет, сейчас он переехал на новый движок, но старые темы и аккаунты мы постарались сохранить максимально аккуратно.

    Форум не связан с магазинами и сервисами – мы ничего не продаём и не даём «рекламу под видом совета». Отвечают обычные участники и модераторы, которые следят за порядком и качеством подсказок.

    Если вы у нас впервые, загляните на страницу о форуме и правила – там коротко описано, как задать вопрос так, чтобы быстро получить ответ. Чтобы создавать темы и писать сообщения, сначала зарегистрируйтесь, а затем войдите под своим логином.

    Не знаете, с чего начать? Создайте тему с описанием проблемы – подскажем и при необходимости перенесём её в подходящий раздел.
    Задать вопрос Новые сообщения Как правильно спросить
    Если пришли по старой ссылке со старого Tehnari.ru – вы на нужном месте, просто продолжайте обсуждение.

Помогите с массивами в TP

PHILOSOPH13

Ученик
Регистрация
15 Апр 2010
Сообщения
10
Реакции
0
Баллы
0
Помогите с массивами в TP

дан массив размера N.Найти кол-во участков,на которых его элементы монотонно убывают.
 
А почему бы не попробовать самому составить алгоритм, попытаться решить? А мы тогда подскажем, что непонятно или не получается. Это и есть помощь
 
друг,у меня это займет уйму времени,я понимаю суть задачи и могу составить ее алгоритм,но на TP ее написать затрудняюсь...сдавать нужно уже после завтра...
 
А интересно, какое минимальное количество членов массива предполагает "монотонное убывание"? Два? Три? Больше? Как задается массив? Какой тип данных?
 
тип данных любой,если что сам подредактирую,убывание от двух и более...массив можно задать самому,можно и рандомом...без разницы)
 
Тогда, например, так:
Код:
CONST
 N=100;
VAR
 A:ARRAY[1..N] of WORD;
 i:INTEGER;
 Num,p:BYTE;
 b:Boolean;
BEGIN
 RANDOMIZE;
 For i:=1 to N do
  begin
   A[i]:=RANDOM(1000);
   Write(A[i]:4);
  end;
 WriteLn;
 Num:=0;
 i:=1;
 Repeat
  b:=true;
  p:=0;
  Repeat
   INC(i);
   If A[i]<A[i-1] then
    begin
     b:=false;
     p:=1;
    end else b:=true;
  Until b or (i=N);
  If p=1 then INC(Num);
 Until i=N;
 WriteLn('The number od "falling" sections is ',Num);
 ReadLn;
END.
 
огромное спасибо,реально выручил)))))
 
усе,доработал,теперь в массиве сам задаю N))))спасибо,сам бы реально много времени потратил бы...)))
 
Назад
Сверху