IPB
ЛогинПароль:

> Прочтите прежде чем задавать вопрос!

1. Заголовок темы должен быть информативным. В противном случае тема удаляется ...
2. Все тексты программ должны помещаться в теги [code=pas] ... [/code].
3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали!
4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора).
5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM!
6. Одна тема - один вопрос (задача)
7. Проверяйте программы перед тем, как разместить их на форуме!!!
8. Спрашивайте и отвечайте четко и по существу!!!

> Метод простых итераций, Решение СЛАУ
Eclipse_dp
сообщение 17.03.2010 23:56
Сообщение #1





Группа: Пользователи
Сообщений: 1
Пол: Мужской
Реальное имя: Андрей

Репутация: -  0  +


Ребят нужна помощь, нужно написать программку для решения СЛАУ методом итераций.
Program zadacha1;
type
matriza= array[1..100,1..100] of real;
Var b,prob,x,x1: array[1..100] of real;
i,j:real;
e:real;
n:integer;
Procedure vvod(var n:integer;var E:real; i,j:integer;var b:array of real;var a:matriza);
begin
Write('vvedite razmer matritci n');
Readln(n);
For i:=1 to n do
For j:=1 to n do begin
Write('A[',i,',',j,']=');
Readln(A[i,j]);
end;
For i:=1 to n do
If a[i,i]=0 then begin
Writeln('oshibka vvoda');
end;
For i:=1 to n do begin
Write('b[',i,']=');
Readln(b[i]);
end;
Write('vvedite tochnost E=');
Readln(E);
end;
Function otv(i,j:integer; var b,x,x1:array of real;a:matriza):real;
begin
For i:=1 to n do
begin
For i:=1 to n do
begin
If i=j then
a[i,j]:=-a[i,j]/a[i,i];
end;
b[i]:=b[i]/a[i,i];
a[i,i]:=0;
end;
For i:=1 to n do
begin
For j:=1 to n do
Write(a[i,j]4.gif2,'');
Write(b[i]4.gif2,'');
end;
For i:=1 to n do
x[i]:=0;
repeat
For i:=1 to n do
begin
For j:=1 to n do
x1[i]:=x1[i]+a[i,j]*x[j];
x1[i]:=x1[i]+b[i];
end;
For i:=1 to n do
begin
x[i]:=x1[i];
x1[i]:=0;
end;
until abs(x1[i]-x[i])<E;
otv:=x[i];
end;

Procedure vivod(i,n:integer;var otv:array of real);
begin
For i:=1 to n do
Writeln(otv[i]);
end;
begin
vvod(n,a,b);
otv(i,j,b);
vivod(otv[i]);
end.

Вот примерный код программы, но он щитает с ошибками, большая просьба помочь разобраться в этом методе sad.gif

Сообщение отредактировано: Eclipse_dp - 18.03.2010 0:10
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 

Сообщений в этой теме


 Ответить  Открыть новую тему 
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 



- Текстовая версия 19.07.2025 23:10
Хостинг предоставлен компанией "Веб Сервис Центр" при поддержке компании "ДокЛаб"