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

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

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

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

Использование методов внутренней сортировки.

Svetlanka

Новые
Регистрация
15 Ноя 2010
Сообщения
34
Реакции
0
Баллы
0
Использование методов внутренней сортировки.

Массив a длины n содержит элементы разных знаков. Составить программу построения массива b, в котором все подряд идущие элементы массива a одного знака были бы заменены их суммой, как в следующем примере: a={1, 2, -3, -4, 5}, b={3, -7, 5}.
 
помогите пжл!!!!!!!!
Вообще-то с этого и стоило бы начать, а не обращаться к нам, как к прислуге.
Ну пожалуйста:
Код:
CONST
 N=10;
VAR
 A,B:ARRAY[1..N] of Integer;
 M:Byte;
 i:Integer;

Function Sign(s:integer):ShortInt;
 begin
  If s<0 then Sign:=-1 else
  If s>0 then Sign:=1 else
  Sign:=0;
 end;

BEGIN
 For i:=1 to N do
  begin
   Write('A[',i:2,']= ');
   ReadLn(A[i]);
  end;
 M:=1;
 i:=1;
 REPEAT
  B[M]:=A[i];
  Repeat
   Inc(i);
   If Sign(A[i])=Sign(A[i-1]) then
    B[M]:=B[M]+A[i];
  Until (Sign(A[i])<>Sign(A[i-1])) or (i=N);
  If i<N then Inc(M);
 UNTIL i=N;
 For i:=1 to N do
  Write(A[i]:5);
 WriteLn;
 For i:=1 to M do Write(B[i]:5);
 ReadLn;
END.
 
Назад
Сверху