Водномерном массиве м, состоящем из 10 целых чисел, найти: а) количество нулевых элементов: б) сумму элементов, больших -4: в) полу сумму элементов с четными индексами: г) произведение нечетных элементов
Var a: array[0..9] of Integer; i,n,nol,otr,nochet: Integer; chet: Real; begin nochet:=1; for i:=0 to 9 do begin writeln('Введите ',i+1,' число'); readln(n); a[i]:=n; end; for i:=0 to 9 do begin if a[i]=0 then nol:=nol+1; if a[i]>-4 then otr:=otr+1; if i mod 2=0 then chet:=chet+1 else nochet:=nochet*a[i]; end; chet:=chet/2; writeln('Кол-во нулевых элементов: ',nol); writeln('Сумма элементов, больше -4: ',otr); writeln('Полу-сумма элементов с чётными индексами: ', chet); writeln('Произведение нечётных элементов: ',chet); end.
#include <iostream>#include <ctime>//Бібліотека для рандомуusing namespace std;int main(){ int array[10];//Масив int Max_Num=0,Min_Num=0;// Мінімальне і Максимальне числа bool Positive_or_negative=0;//Число додатнє чи відємне srand(time(NULL));//Рандом.Кожний раз інший. for(int i=0;i<10;++i) { Positive_or_negative=rand()%2; if(Positive_or_negative==false)//якщо Positive_or_negative==0 { array[i]=-(rand()%10);//Рандом від -10...0 } else { array[i]=rand()%10;//Рандом від 0...10 } if(array[i]>Max_Num)//Пошук макс. числа { Max_Num=array[i]; } if(array[i]<Min_Num)//Пошук Мін. числа { Min_Num=array[i]; } cout<<array[i]<<" "; } cout<<endl<<"Max. number is:"<<Max_Num<<endl;//Вивід максимально числа cout<<"Min. number is:"<<Min_Num<<endl;//Вивід мінімально числа system("pause>>void");//закінчення программи.}
Без проверки полагаем, что по заданным координатам точек можно построить треугольники.
//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 Площадь второго треугольника больше
i,n,nol,otr,nochet: Integer;
chet: Real;
begin
nochet:=1;
for i:=0 to 9 do
begin
writeln('Введите ',i+1,' число');
readln(n);
a[i]:=n;
end;
for i:=0 to 9 do
begin
if a[i]=0 then nol:=nol+1;
if a[i]>-4 then otr:=otr+1;
if i mod 2=0 then chet:=chet+1 else nochet:=nochet*a[i];
end;
chet:=chet/2;
writeln('Кол-во нулевых элементов: ',nol);
writeln('Сумма элементов, больше -4: ',otr);
writeln('Полу-сумма элементов с чётными индексами: ', chet);
writeln('Произведение нечётных элементов: ',chet);
end.