Составить блок схему в turbo pascal алгоритма и программу для вычисления функции по формуле для произвольных исходных данных, с двойной точностью:
пример выполнения
program prak;
uses crt, printer;
const
c = 4.67;
var
alpha, y: real;
a, b: real;
begin
clrscr;
write(‘введите alpha’);
readln(alpha);
a : = ln(alpha)/(2 + cos(alpha * sqr(alpha));
b : = sqrt(abs(sqr(sin(alpha)) * sin(alpha)) - exp(alpha));
y : = a + b + c;
writeln(‘исходные данные’);
writeln(‘alpha = ‘, alpha: 11: 4);
writeln(‘промежуточные данные’);
writeln(‘a = ‘, a: 10: 3, ‘ b = ‘, b: 10: 3);
writeln(‘результат’);
writeln(‘ y = ‘, y: 12: 5);
end.
program laba;
{$APPTYPE CONSOLE}
uses
SysUtils,
windows;
var
a:array[1..15] of integer;
i,imax,x:integer;
begin
SetConsoleoutputCP(1251);
for i:=1 to 15 do
begin
writeln('Введите',i,'-й элемент');
readln(a[i]);
end;
imax:=1;
for i:=2 to 15 do
if a[i]>a[imax] then imax:=i;
x:=a[15];
writeln('максимальное число = ',a[imax],' его индекс= ',imax);
if imax=15 then write('Он последний, обмена нет');
else
begin
x:=a[imax];
a[imax]:=a[15];
a[15]:=x;
writeln('Обмен максимального и последнего:');
for i:=1 to 15 do
write(a[i]:6:3,' ');
end;
readln;
end.
Объяснение:
Sub Swap()
Dim r As Range, A As Variant
Dim i As Integer, im As Double, n As Integer, t As Double
n = 15
Set r = Range(Cells(1, 1), Cells(1, n))
A = r
im = 1
For i = 2 To n
If A(1, i) > A(1, im) Then
im = i
End If
Next i
t = A(1, im)
A(1, im) = A(1, n)
A(1, n) = t
Set r = Range(Cells(2, 1), Cells(2, n))
r = A
End Sub
На лист в ячейки А1 - О1 заносим исходные 15 чисел
На этот же лист через проект помещаем макрос и запускаем.
Результат будет в ячейках А2 - О2