/ PascalABC.NET 3.2, сборка 1436 от 01.05.2017 // Внимание! Если программа не работает, обновите версию!
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.
Пример 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
Const N = 3; M = 4; Var A:array[1..N,1..M] of integer; i,j,iMin,jMin:integer; Begin Randomize; iMin:=1; jMin:=1; WriteLn('Исходный массив:'); For i:= 1 to N do Begin For j:= 1 to M do Begin A[i,j]:=random(76)-30; if A[i,j] < A[iMin,jMin] then Begin iMin:=i; jMin:=j End; Write(A[i,j]:3,' ') End; WriteLn; End; WriteLn('Min = A[',iMin,',',jMin,'] = ',A[iMin,jMin]); End.
1) 2,25 Мбайт, 2) 64 Мбайт, 3) 112,5 Мбайт
Объяснение:
1) K=1024*768 - количество пикселей
N=16777216 - количество цветов палитре
Решение N=2^i
I=K*i
16777216=2^24=2^i. Значит i=24 бита
I=1024*768*24/(8*1024)=2304 Кбайт=2,25 Мбайт
2) Дано:
N = 16 777 216
К = 1600 х 1200
Надо найти I
Решение: N=2^i
I=K*i
16777216=2^24=2^i. Значит i=24 бита
I = 1600 · 1200 · 24 = 46 080 000 бит
46 080 000 бит = 5 760 000 байт = 5625 Кб = 5,5 Мб
Значит подойдет видеокарта лишь с 64 Мбайт.
3) Дано:
i = 16 битов
К = 1024 х 768
Частота обновления экрана = 75 Гц
Надо найти I
I = K · i
I = 1024 · 768 · 16 = 12 582 912 бит
12 582 912 бит = 1 572 864 байт = 1536 Кб = 1,5 Мб
Частота обновления означает, что за 1 с обновится 75 раз.
1,5 · 75 = 112,5 Мб