<em>/ PascalABC.NET 3.2, сборка 1436 от 01.05.2017</em>
<em>// Внимание! Если программа не работает, обновите версию!</em>
begin
var m:=ArrRandom(ReadInteger('n='),-99,99).Select(i->i/10).ToArray;
m.Println;
var mx:=m.MaxBy(x->Abs(x));
Writeln('Номер первого максимального по модулю элемента: ',
m.IndexOf(mx)+1);
Writeln('Искомая сумма: ');
var i:=m.FindIndex(x->x>0);
if (i=-1) or (i=m.Length-1) then Writeln(0)
else Writeln(m[i+1:].Sum);
var a,b:integer;
Write('Введите границы интервала: '); Read(a,b);
var t:=m.Where(x->Trunc(x) in [a..b]).ToArray;
t:=t+m.Where(x-> not (Trunc(x) in [a..b])).ToArray; t.Println;
end.
<u>Пример</u>
n= 10
-3 3.7 9.9 -3.8 1.6 -8.4 5.7 -7.9 -9.4 7.8
Номер первого максимального по модулю элемента: 3
Искомая сумма:
-4.5
Введите границы интервала: -5 5
-3 3.7 -3.8 1.6 5.7 9.9 -8.4 -7.9 -9.4 7.8
80 Кбайт = 80 *2^(13) =5*2^4 *2^13=5*2^(17) бит
40*32*64= 5*2^3 * 2^5 * 2^6 = 5*2^(14) символов
5*2^(17) / (5*2^14)= 2^3 = 8 бит для одного символа
Выписываем значения переменных из строк, где Х=1
На первом шаге цикла, ты пытаешся обратиться к A[1], т.к. цикл с i начинается с единицы, а массив у тебя объявлен как [10..99]. Объяви массив как [1..90].
И рандом(если тебе от 10 до 99) правильней m[i] := random(90)+10;