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

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

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

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

Помогите с задачей в паскале на одномерные массивы

  • Автор темы Автор темы QIWI
  • Дата начала Дата начала

QIWI

Ученик
Регистрация
13 Май 2012
Сообщения
7
Реакции
0
Баллы
0
Помогите с задачей в паскале на одномерные массивы

Найти сумму всех элементов массива расположенных после первого положительного элемента и преобразить массив таким образом, чтобы сначала располагались элементы, целая часть которых лежит в интервале [a,b] и потом все остальные.
 
Найти сумму всех элементов массива расположенных после первого положительного элемента и преобразить массив таким образом, чтобы сначала располагались элементы, целая часть которых лежит в интервале [a,b] и потом все остальные.
Легко:
Код:
Const
 N=20;
Var
 i,j,a,b:Byte;
 Sum,D:Real;
 V:Array[1..N] of Real;
 R:boolean;
Begin
 Randomize;
 R:=false;
 Sum:=0;
 Writeln('Initial array:');
 For i:=1 to N do
  begin
   V[i]:=100*Random-50;
   If R then Sum:=Sum+V[i];
   If (V[i]>0) and Not(R) then R:=true;
   Write(V[i]:8:3);
  end;
 Writeln;
 Writeln;
 Writeln('Sum= ',Sum:0:3);
 Writeln;
 Writeln;
 Write('a (lower limit) = ');
 Readln(a);
 Write('b (upper limit) = ');
 Readln(b);
 Writeln('Ordered array:');
 Writeln;
 Writeln;
 For i:=1 to N-1 do
  For j:=N downto i+1 do
   If ((Trunc(V[j])>=a) and (Trunc(V[j])<=b)) and
      ((Trunc(V[j-1])<a) or (Trunc(V[j-1])>b)) then
    begin
     D:=V[j-1];
     V[j-1]:=V[j];
     V[j]:=D;
    end;
 For i:=1 to N do
  Write(V[i]:8:3);
 Readln
End.
 
Спасибо большое!!
 
Назад
Сверху