Можно заметить, что самый большой угол в треугольнике всегда расположен напротив самой длинной стороны, которую мы обозначим буквой с. Значение такого угла можно найти по теореме косинусов:
В остроугольном треугольнике угол всегда будет меньше 90 градусов, поэтому его косинус всегда будет положительным. В прямоугольном треугольнике косинус будет равен нулю, а в тупоугольном он будет отрицательным. На этом можно построить решение, предварительно определив, какая из сторон является самой длинной. И, само собой разумеется, надо сразу после ввода проверить условие существования треугольника, т.е. чтобы сумма длин двух его любых сторон была больше третьей.
var a,b,c,a1,b1,c1,cosC:real; begin Write('Введите длины сторон треугольника: '); Read(a,b,c); Write('Треугольник '); if (a<(b+c)) and (b<(a+c)) and (c<(a+b)) then begin if a>b then if a>c then begin c1:=a; a1:=c; b1:=b end else begin c1:=c; a1:=a; b1:=b end else if b>c then begin c1:=b; a1:=a; b1:=c end else begin c1:=c; a1:=a; b1:=b end; cosC:=(sqr(a1)+sqr(b1)-sqr(c1))/(2*a*b); if cosC<0 then Writeln('тупоугольный') else if cosC=0 then Writeln('прямоугольный') else Writeln('остроугольный') end else Writeln('построить невозможно') end.
Тестовое решение: Введите длины сторон треугольника: 6 4.1 4 Треугольник тупоугольный
Const n=5;m=10; var b:array[1..n,1..m]of integer; i,j,k,buf,l:integer; begin for i:=1 to n do begin writeln; for j:=1 to m do begin b[i,j]:=random(50); write(b[i,j]:4); end; end; writeln; for j:=1 to m do begin k:=0; for i:=1 to n-1 do if b[i,j]<b[i+1,j]then k:=k+1; if k=n-1 then buf:=buf+1; end; k:=0; for l:=2 to m do if l mod 2=0 then for i:=1 to n-1 do for j:=i+1 to n do if b[i,l]>b[j,l]then begin k:=b[i,l]; b[i,l]:=b[j,l]; b[j,l]:=k; end; writeln('увеличилось ',m div 2-buf); for i:=1 to n do begin writeln; for j:=1 to m do write(b[i,j]:4); end; end.
Значение такого угла можно найти по теореме косинусов:
В остроугольном треугольнике угол всегда будет меньше 90 градусов, поэтому его косинус всегда будет положительным. В прямоугольном треугольнике косинус будет равен нулю, а в тупоугольном он будет отрицательным. На этом можно построить решение, предварительно определив, какая из сторон является самой длинной. И, само собой разумеется, надо сразу после ввода проверить условие существования треугольника, т.е. чтобы сумма длин двух его любых сторон была больше третьей.
var
a,b,c,a1,b1,c1,cosC:real;
begin
Write('Введите длины сторон треугольника: ');
Read(a,b,c);
Write('Треугольник ');
if (a<(b+c)) and (b<(a+c)) and (c<(a+b)) then begin
if a>b then
if a>c then begin c1:=a; a1:=c; b1:=b end
else begin c1:=c; a1:=a; b1:=b end
else
if b>c then begin c1:=b; a1:=a; b1:=c end
else begin c1:=c; a1:=a; b1:=b end;
cosC:=(sqr(a1)+sqr(b1)-sqr(c1))/(2*a*b);
if cosC<0 then Writeln('тупоугольный')
else
if cosC=0 then Writeln('прямоугольный')
else Writeln('остроугольный')
end
else Writeln('построить невозможно')
end.
Тестовое решение:
Введите длины сторон треугольника: 6 4.1 4
Треугольник тупоугольный
n=5;m=10;
var
b:array[1..n,1..m]of integer;
i,j,k,buf,l:integer;
begin
for i:=1 to n do
begin
writeln;
for j:=1 to m do
begin
b[i,j]:=random(50);
write(b[i,j]:4);
end;
end;
writeln;
for j:=1 to m do
begin
k:=0;
for i:=1 to n-1 do
if b[i,j]<b[i+1,j]then
k:=k+1;
if k=n-1 then
buf:=buf+1;
end;
k:=0;
for l:=2 to m do
if l mod 2=0 then
for i:=1 to n-1 do
for j:=i+1 to n do
if b[i,l]>b[j,l]then
begin
k:=b[i,l];
b[i,l]:=b[j,l];
b[j,l]:=k;
end;
writeln('увеличилось ',m div 2-buf);
for i:=1 to n do
begin
writeln;
for j:=1 to m do
write(b[i,j]:4);
end;
end.