1.найти в массиве те элементы, значение которых меньше среднего арифметического, взятого от всех элементов массива. 2.массив а вводится с клавиатуры. найти среднее арифметическое его элементов с нечетными номерами. размер произвольный. заранее
//1) var A: array [1..8] of integer; i: byte; sum: integer; Arifm: real; begin writeln('Заполнение массива.'); sum := 0; for i := 1 to 8 do begin write('A[',i,'] = '); readln(A[i]); sum := sum + A[i]; end; Arifm := sum/8; writeln('Среднее арифметическое всех элементов = ', Arifm); writeln; writeln('Элементы меньше среднего арифметического.'); for i := 1 to 8 do if A[i] < Arifm then write(A[i]:4); writeln; readln; end.
//2) var A: array [1..8] of integer; i: byte; sum: integer; Arifm: real; begin writeln('Заполнение массива.'); sum := 0; for i := 1 to 8 do begin write('A[',i,'] = '); readln(A[i]); if i mod 2 <> 0 then sum := sum + A[i]; end; Arifm := sum/4; writeln('Среднее арифметическое элементов с нечетн. индексами = ', Arifm); readln; end.
1) program Ok; const n = 10; var A:array[1..n] of real; sum:real; i:integer; begin sum:=0; for i:=1 to n do begin read(A[i]); sum:=sum+A[i]; end; sum:=sum/n; for i:=1 to n do begin if(A[i]<sum) then writeln(A[i]); end; end. 2) program Ok; const n = 10; varA:array[1..n] of real; sum:real; i,k:integer; begin sum:=0; for i:=1 to n do begin read(A[i]); if (i mod 2 = 1) then sum:=sum+A[i]; if (i mod 2 = 1) then k:=k+1; end; sum:=sum/k; write(sum); end.
Без проверки полагаем, что по заданным координатам точек можно построить треугольники.
//PascalABC.Net 3.0, сборка 1111 type Point=record x,y:double end;
function TriangleSquare(A,B,C:Point):double; begin Result:=0.5*abs(A.x*(B.y-C.y)+B.x*(C.y-A.y)+C.x*(A.y-B.y)) end;
procedure GetPoint(c:char; var A:Point); begin Write('Введите координаты точки ',c,': '); Readln(A.x,A.y) end;
var A:array['A'..'F'] of Point; i:'A'..'F'; s1,s2:double; begin for i:='A' to 'F' do GetPoint(i,A[i]); s1:=TriangleSquare(A['A'],A['B'],A['C']); s2:=TriangleSquare(A['D'],A['E'],A['F']); if s1>s2 then Writeln('Площадь первого треугольника больше') else if s2>s1 then Writeln('Площадь второго треугольника больше') else Writeln('Площади треугольников равны') end.
Тестовое решение: Введите координаты точки A: -4 3.7 Введите координаты точки B: -6.3 0 Введите координаты точки C: 10.2 5.93 Введите координаты точки D: 7.143 8.1 Введите координаты точки E: -6 -3 Введите координаты точки F: 7.4 -5.7 Площадь второго треугольника больше
Sub Ìàêðîñ1() Dim Sum(heigth - 1, width - 1) Dim Product(heigth - 1, width - 1)
For i = 0 To heigth - 1 For j = 0 To width - 1 Sum(i, j) = i + j Product(i, j) = i * j Next j Next i
Call Show(Sum, 0, 0) Call Show(Product, 0, 12) End Sub
Sub Show(ByRef m, dx, dy) For i = 0 To heigth - 1 For j = 0 To width - 1 ActiveSheet.Cells(dx + i + 1, dy + j + 1).Value = Hex(m(i, j)) Next j Next i End Sub
//1)
var
A: array [1..8] of integer;
i: byte;
sum: integer;
Arifm: real;
begin
writeln('Заполнение массива.');
sum := 0;
for i := 1 to 8 do
begin
write('A[',i,'] = ');
readln(A[i]);
sum := sum + A[i];
end;
Arifm := sum/8;
writeln('Среднее арифметическое всех элементов = ', Arifm);
writeln;
writeln('Элементы меньше среднего арифметического.');
for i := 1 to 8 do
if A[i] < Arifm then
write(A[i]:4);
writeln; readln;
end.
//2)
var
A: array [1..8] of integer;
i: byte;
sum: integer;
Arifm: real;
begin
writeln('Заполнение массива.');
sum := 0;
for i := 1 to 8 do
begin
write('A[',i,'] = ');
readln(A[i]);
if i mod 2 <> 0 then
sum := sum + A[i];
end;
Arifm := sum/4;
writeln('Среднее арифметическое элементов с нечетн. индексами = ', Arifm);
readln;
end.