
07.04.2012, 10:51
|
Прохожий
|
|
Регистрация: 06.04.2012
Сообщения: 8
Репутация: 10
|
|
Спасибо за найденные ошибки. Но проблему не решило.
Что касается массива brr, то он и должен быть меньше оригинального. Т.к. если раскладывать по одной строке то в качестве алг. дополнения будет выступать матрица меньшей размерности.
Вот исправленная версия:
Код:
program LaplasRule;
{$APPTYPE CONSOLE}
uses
SysUtils,Math;
type
darr = array of array of single;
var
arr:darr; {исходная матрица}
det:real;
function lap(crr:darr): single; {собственно тут ошибка}
var
i,j,l,s:integer; {i-строка; j-столбец; l-столбец, по которуму расскладываем; s-размер исходной матрицы}
brr:array of array of single; {матрица алгеброического дополнения}
begin
s:=high(crr);
if s<>0 then
begin
setlength(brr,s,s);
for l:=0 to s do {выбираем столбец по которому раскладываем}
begin
for j:=0 to l-1 do {перенос элементов из исх. матрицы в матрицу алг. доп.}
for i:=1 to s do
brr[i-1,j]:=crr[i,j];
for j:=l+1 to s do
for i:=1 to s do
brr[i-1,j-1]:=crr[i,j];
lap:=crr[1,l]*lap(brr)*intpower(-1,l+1)+lap
end
end
else
lap:=crr[1,1] {для случая когда матрица 1x1 :3}
end;
begin
setlength(arr,4,4); {исходная матрица}
arr[0,0]:=3;
arr[0,1]:=3;
arr[0,2]:=4;
arr[0,3]:=2;
arr[1,0]:=1;
arr[1,1]:=2;
arr[1,2]:=2;
arr[1,3]:=1;
arr[2,0]:=1;
arr[2,1]:=3;
arr[2,2]:=4;
arr[2,3]:=1;
arr[3,0]:=0;
arr[3,1]:=1;
arr[3,2]:=1;
arr[3,3]:=1; {определитель исходной матрицы равен 1}
det:=lap(arr);
writeln(det) {вывод определителя}
end.
Здесь компилятор выдает:
Код:
lap:=crr[1,l]*lap(brr)*intpower(-1,l+1)+lap
end
Такие ошибки:
Код:
[Error] LaplasRule.dpr(34): Incompatible types
[Error] LaplasRule.dpr(35): Not enough actual parameters
|