Технический форум
Вернуться   Технический форум > Программирование > Форум программистов > Delphi, Kylix and Pascal


Ответ
 
Опции темы Опции просмотра
Старый 15.11.2010, 17:16   #1 (permalink)
Svetlanka
Member
 
Регистрация: 15.11.2010
Сообщений: 34
Сказал(а) спасибо: 0
Поблагодарили 0 раз(а) в 0 сообщениях
Репутация: 10
Red face Использование методов внутренней сортировки.

Массив a длины n содержит элементы разных знаков. Составить программу построения массива b, в котором все подряд идущие элементы массива a одного знака были бы заменены их суммой, как в следующем примере: a={1, 2, -3, -4, 5}, b={3, -7, 5}.
Svetlanka вне форума   Ответить с цитированием

Старый 15.11.2010, 17:16
Helpmaster
Member
 
Аватар для Helpmaster
 
Регистрация: 08.03.2016
Сообщений: 0

Так же вы можете найти интересующую вас информацию в аналогичных топиках

Методы сортировки
Быстрый метод сортировки(Делфи)
Сортировки массива по убыванию суммы цифр элементов
Использование Windows7

Старый 15.11.2010, 18:01   #2 (permalink)
Svetlanka
Member
 
Регистрация: 15.11.2010
Сообщений: 34
Сказал(а) спасибо: 0
Поблагодарили 0 раз(а) в 0 сообщениях
Репутация: 10
По умолчанию

помогите пжл!!!!!!!!
Svetlanka вне форума   Ответить с цитированием
Старый 15.11.2010, 21:56   #3 (permalink)
Vladimir_S
Специалист
 
Регистрация: 27.08.2008
Адрес: Санкт-Петербург
Сообщений: 27,807
Сказал(а) спасибо: 340
Поблагодарили 583 раз(а) в 208 сообщениях
Репутация: 113184
По умолчанию

Цитата:
Сообщение от Svetlanka Посмотреть сообщение
помогите пжл!!!!!!!!
Вообще-то с этого и стоило бы начать, а не обращаться к нам, как к прислуге.
Ну пожалуйста:
Код:
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.
Vladimir_S вне форума   Ответить с цитированием
Старый 15.11.2010, 23:25   #4 (permalink)
Svetlanka
Member
 
Регистрация: 15.11.2010
Сообщений: 34
Сказал(а) спасибо: 0
Поблагодарили 0 раз(а) в 0 сообщениях
Репутация: 10
По умолчанию

Спасибо большое!!!
Svetlanka вне форума   Ответить с цитированием
Ads

Яндекс

Member
 
Регистрация: 31.10.2006
Сообщений: 40200
Записей в дневнике: 0
Сказал(а) спасибо: 0
Поблагодарили 0 раз(а) в 0 сообщениях
Репутация: 55070
Ответ


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

BB коды Вкл.
Смайлы Вкл.
[IMG] код Выкл.
HTML код Выкл.
Trackbacks are Вкл.
Pingbacks are Вкл.
Refbacks are Выкл.




Часовой пояс GMT +4, время: 05:09.

Powered by vBulletin® Version 6.2.5.
Copyright ©2000 - 2014, Jelsoft Enterprises Ltd.