Модераторы: Poseidon
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> [Pascal>delphi6] переделать готовую курс. работу ", метод жордана-гауса для линейных ур-ний 
:(
    Опции темы
geniy
Дата 25.4.2007, 17:01 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 5
Регистрация: 25.4.2007

Репутация: нет
Всего: нет



Код

program j_g;
const
 n1=7;
 n2=7;
type matr=array [1..n1,1..n2] of real;
     V=array [1..n1] of real;
var
Matr_Gl,Matr_Inv:matr;
p,q,u:integer;
S1:V;
procedure Vvod_Matr(var mat:matr; var ur:integer; var S:V);
var
i,j: integer;
begin
 write('Skolko uravneniy ' );
 readln(ur);
 for i:=1 to ur do
  for j:=1 to ur do
   begin
      write('Vvedite element uravneni [',i,',',j,'] ');
      readln(mat[i,j]);
   end;
 for i:=1 to ur do begin
  writeln('vvedite kontrol summu ');
  write(i, 'stroki : ');
  readln(S[i]);
 end;
end;
procedure Matrinvers(p,q:integer; m1:matr; var m2:matr; var ur:integer;var S:V);
var
i,j,n11,n21: integer;
begin
 for i:=1 to ur do
  for j:=1 to ur do
   begin
     m2[i,j]:=m1[i,j]-((m1[i,p]*m1[q,j])/m1[q,p]);
     if j=p then m2[i,j]:=0;
     if i=q then m2[q,j]:=m1[q,j];
   end;
 for i:=1 to n2 do begin
  if i=q then  S[i]:=S[q] else
  S[i]:=S[i]-((m1[i,p]*S[q])/m1[q,p]);
 end;
end;
procedure swop(var m1:matr;var m2:matr;u:integer);
 var
  i,j:integer;
  buf:real;
begin
 for i:=1 to u do
  for j:=1 to u do
  begin
     buf:=m1[i,j];
     m1[i,j]:=m2[i,j];
     m2[i,j]:=buf;
  end;
end;
procedure Out_Matr(m:matr;u:integer);
var
 i,j:integer;
begin
 for i:=1 to u do
 begin
  for j:=1 to u do
  begin
   write(m[i,j]:7:3);
  end;
  writeln;
 end;
end;
 var
  i,j,n:integer;
  f:text;
{Ha4alo programbI}
begin
  Vvod_Matr(Matr_Gl,u,S1);
 if u>1 then
 for n:=1 to u do begin
 Out_Matr(Matr_Gl,u);
 write('Vvedite poziciu razgrshauchego element (not 0)(stroka, ctolbets) ');
 read(q,p);
 Matrinvers(p,q,Matr_Gl,Matr_Inv,u,S1);
 writeln;
 swop(Matr_Gl,Matr_Inv,u);
 end;
 Out_Matr(Matr_Gl,u);
 for i:=1 to u do writeln('S',i,'=',S1[i]:8:3);
 writeln;
 for i:=1 to u do begin
 writeln('X',i,' = ',S1[i]/Matr_Gl[i,i]:8:3);
 readln;
 end;
 begin
 assign(f,'a.txt');
 rewrite (f);
    for i:=1 to u do begin
    writeln(f,'X',i,' = ',S1[i]/Matr_Gl[i,i]:8:3);
    end;
 close (f);
 end;
 end.



Это сообщение отредактировал(а) geniy - 25.4.2007, 17:36
PM MAIL   Вверх
Rodman
Дата 25.4.2007, 17:03 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


CIO
****


Профиль
Группа: Участник
Сообщений: 6144
Регистрация: 7.5.2006
Где: Ukraine ⇛ Kyiv ci ty

Репутация: 26
Всего: 122



Вы наверно сговорились...

Тебе под визуальное или под консоль???
PM MAIL WWW Skype GTalk YIM MSN   Вверх
geniy
Дата 25.4.2007, 17:07 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 5
Регистрация: 25.4.2007

Репутация: нет
Всего: нет



привет! мне с формой, визуальное
PM MAIL   Вверх
geniy
Дата 25.4.2007, 21:04 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 5
Регистрация: 25.4.2007

Репутация: нет
Всего: нет



сама программа универсальная, считает систему уравнений, матрица которой имеет любой размер.
может быть полезна!
я думаю интересная программа получиться!
PM MAIL   Вверх
Rodman
Дата 26.4.2007, 09:21 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


CIO
****


Профиль
Группа: Участник
Сообщений: 6144
Регистрация: 7.5.2006
Где: Ukraine ⇛ Kyiv ci ty

Репутация: 26
Всего: 122



я не совсем уверен, но вот накидал...
Код

unit Unit1;

interface

uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, StdCtrls, Grids, ExtCtrls, Buttons;

const
 n1=7;
 n2=7;
type matr=array [1..n1,1..n2] of real;
     V=array [1..n1] of real;
type
  TFrm = class(TForm)
    BitBtn1: TBitBtn;
    RangMatrixEdt: TLabeledEdit;
    EpsEdt: TLabeledEdit;
    InputGrd: TStringGrid;
    OutputGrd: TStringGrid;
    LblA: TLabel;
    LblB: TLabel;
    LabeledEdit1: TLabeledEdit;
    StringGrid1: TStringGrid;
    StringGrid2: TStringGrid;
    StringGrid3: TStringGrid;
    BitBtn2: TBitBtn;
    procedure FormCanResize(Sender: TObject; var NewWidth,
      NewHeight: Integer; var Resize: Boolean);
    procedure InputGrdSetEditText(Sender: TObject; ACol, ARow: Integer;
      const Value: String);
    procedure FormActivate(Sender: TObject);
    procedure BitBtn1Click(Sender: TObject);
    procedure Vvod_Matr(var mat:matr; var ur:integer; var S:V);
    procedure swop(var m1:matr;var m2:matr;u:integer);
    procedure Matrinvers(p,q:integer; m1:matr; var m2:matr; var ur:integer;var S:V);
    procedure Out_Matr(m:matr;u:integer);
    procedure BitBtn2Click(Sender: TObject);
  private
    { Private declarations }
  public
    { Public declarations }
  end;

var
  Frm: TFrm;
  Matr_Gl,Matr_Inv:matr;
  p,q,u:integer;
  S1:V;

implementation
uses math, Unit2;
{$R *.dfm}

procedure TFrm.Vvod_Matr(var mat:matr; var ur:integer; var S:V);
var i,j: integer;
begin
 write('Skolko uravneniy ' );
 readln(ur);
 for i:=1 to StrToInt(RangMatrixEdt.Text) do
  for j:=1 to StrToInt(RangMatrixEdt.Text) do
      mat[i, j]:=StrToInt(InputGrd.Cells[j,i]);
 for i:=1 to StrToInt(RangMatrixEdt.Text) do
  s[i]:=StrToInt(outputGrd.cells[0, i]);
end;

procedure TFrm.Out_Matr(m:matr;u:integer);
var
 i,j:integer;
begin
 for i:=1 to u do
  for j:=1 to u do
    StringGrid1.Cells[j,i]:=FloatToStr(m[i,j]);
end;

procedure TFrm.swop(var m1:matr;var m2:matr;u:integer);
 var
  i,j:integer;
  buf:real;
begin
 for i:=1 to u do
  for j:=1 to u do
  begin
     buf:=m1[i,j];
     m1[i,j]:=m2[i,j];
     m2[i,j]:=buf;
  end;
end;

procedure TFrm.Matrinvers(p,q:integer; m1:matr; var m2:matr; var ur:integer;var S:V);
var i,j: integer;
begin
 for i:=1 to ur do
  for j:=1 to ur do
   begin
     m2[i,j]:=m1[i,j]-((m1[i,p]*m1[q,j])/m1[q,p]);
     if j=p then m2[i,j]:=0;
     if i=q then m2[q,j]:=m1[q,j];
   end;
 for i:=1 to n2 do begin
  if i=q then  S[i]:=S[q] else
  S[i]:=S[i]-((m1[i,p]*S[q])/m1[q,p]);
 end;
end;

procedure TFrm.BitBtn1Click(Sender: TObject);
var i:Integer;
begin
  Vvod_Matr(Matr_Gl,u,S1);
  q:=StrToInt(EpsEdt.text);
  p:=StrToInt(LabeledEdit1.text);
  Matrinvers(p,q,Matr_Gl,Matr_Inv,u,S1);
  swop(Matr_Gl,Matr_Inv,u);
  Out_Matr(Matr_Gl,u);
  for i:=1 to u do
    StringGrid2.Cells[0, i]:=FloatToStr(S1[i]);
  for i:=1 to u do
    StringGrid3.Cells[0, i]:=FloatToStr(S1[i]/Matr_Gl[i,i]);
end;

procedure TFrm.FormCanResize(Sender: TObject; var NewWidth,
  NewHeight: Integer; var Resize: Boolean);
begin
  Resize:=false;
end;

procedure TFrm.InputGrdSetEditText(Sender: TObject; ACol,
  ARow: Integer; const Value: String);
var floatC:Double;
begin
  if(TryStrToFloat(InputGrd.Cells[ACol, ARow], floatC)=False)then
    ShowMessage('Ïðîâåðüòå ïðàâèëüíîñòü ââåäåííûõ äàííûõ!!!'+#10#13+'Äàííûå äîëæíû ââîäèòüñÿ ÷åðåç çàïÿòóþ...');
end;

procedure TFrm.FormActivate(Sender: TObject);
begin
  RangMatrixEdt.SetFocus;
end;

procedure TFrm.BitBtn2Click(Sender: TObject);
var tList:TStringList;
    i:Integer;
begin
  tList:=TStringList.Create;
  try
    for i:=1 to u do
      tList.Text:=tList.Text+' '+StringGrid3.Cells[0, i];
      tList.SaveToFile('a.txt');
  finally
    tList.Free;
  end;
end;

end.



Присоединённый файл ( Кол-во скачиваний: 10 )
Присоединённый файл  Program.rar 8,16 Kb
PM MAIL WWW Skype GTalk YIM MSN   Вверх
geniy
Дата 26.4.2007, 14:24 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 5
Регистрация: 25.4.2007

Репутация: нет
Всего: нет



Код

unit Unit1;

interface

uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, StdCtrls, Grids, ExtCtrls, Buttons;

const
 n1=7;
 n2=7;
type matr=array [1..n1,1..n2] of real;
     V=array [1..n1] of real;
type
  TFrm = class(TForm)
    BitBtn1: TBitBtn;
    RangMatrixEdt: TLabeledEdit;
    EpsEdt: TLabeledEdit;
    InputGrd: TStringGrid;
    OutputGrd: TStringGrid;
    LblA: TLabel;
    LblB: TLabel;
    LabeledEdit1: TLabeledEdit;
    StringGrid1: TStringGrid;
    StringGrid2: TStringGrid;
    StringGrid3: TStringGrid;
    BitBtn2: TBitBtn;
    procedure FormCanResize(Sender: TObject; var NewWidth,
      NewHeight: Integer; var Resize: Boolean);
    procedure InputGrdSetEditText(Sender: TObject; ACol, ARow: Integer;
      const Value: String);
    procedure FormActivate(Sender: TObject);
    procedure BitBtn1Click(Sender: TObject);
    procedure Vvod_Matr(var mat:matr; var ur:integer; var S:V);
    procedure swop(var m1:matr;var m2:matr;u:integer);
    procedure Matrinvers(p,q:integer; m1:matr; var m2:matr; var ur:integer;var S:V);
    procedure Out_Matr(m:matr;u:integer);
    procedure BitBtn2Click(Sender: TObject);
  private
    { Private declarations }
  public
    { Public declarations }
  end;

var
  Frm: TFrm;
  Matr_Gl,Matr_Inv:matr;
  p,q,u:integer;
  S1:V;

implementation
uses math, Unit2;  \\\ОШИБОЧКА ВОТ ТУТ
{$R *.dfm}

procedure TFrm.Vvod_Matr(var mat:matr; var ur:integer; var S:V);
var i,j: integer;
begin
 write('Skolko uravneniy ' );
 readln(ur);
 for i:=1 to StrToInt(RangMatrixEdt.Text) do
  for j:=1 to StrToInt(RangMatrixEdt.Text) do
      mat[i, j]:=StrToInt(InputGrd.Cells[j,i]);
 for i:=1 to StrToInt(RangMatrixEdt.Text) do
  s[i]:=StrToInt(outputGrd.cells[0, i]);
end;

procedure TFrm.Out_Matr(m:matr;u:integer);
var
 i,j:integer;
begin
 for i:=1 to u do
  for j:=1 to u do
    StringGrid1.Cells[j,i]:=FloatToStr(m[i,j]);
end;

procedure TFrm.swop(var m1:matr;var m2:matr;u:integer);
 var
  i,j:integer;
  buf:real;
begin
 for i:=1 to u do
  for j:=1 to u do
  begin
     buf:=m1[i,j];
     m1[i,j]:=m2[i,j];
     m2[i,j]:=buf;
  end;
end;

procedure TFrm.Matrinvers(p,q:integer; m1:matr; var m2:matr; var ur:integer;var S:V);
var i,j: integer;
begin
 for i:=1 to ur do
  for j:=1 to ur do
   begin
     m2[i,j]:=m1[i,j]-((m1[i,p]*m1[q,j])/m1[q,p]);
     if j=p then m2[i,j]:=0;
     if i=q then m2[q,j]:=m1[q,j];
   end;
 for i:=1 to n2 do begin
  if i=q then  S[i]:=S[q] else
  S[i]:=S[i]-((m1[i,p]*S[q])/m1[q,p]);
 end;
end;

procedure TFrm.BitBtn1Click(Sender: TObject);
var i:Integer;
begin
  Vvod_Matr(Matr_Gl,u,S1);
  q:=StrToInt(EpsEdt.text);
  p:=StrToInt(LabeledEdit1.text);
  Matrinvers(p,q,Matr_Gl,Matr_Inv,u,S1);
  swop(Matr_Gl,Matr_Inv,u);
  Out_Matr(Matr_Gl,u);
  for i:=1 to u do
    StringGrid2.Cells[0, i]:=FloatToStr(S1[i]);
  for i:=1 to u do
    StringGrid3.Cells[0, i]:=FloatToStr(S1[i]/Matr_Gl[i,i]);
end;

procedure TFrm.FormCanResize(Sender: TObject; var NewWidth,
  NewHeight: Integer; var Resize: Boolean);
begin
  Resize:=false;
end;

procedure TFrm.InputGrdSetEditText(Sender: TObject; ACol,
  ARow: Integer; const Value: String);
var floatC:Double;
begin
  if(TryStrToFloat(InputGrd.Cells[ACol, ARow], floatC)=False)then
    ShowMessage('Проверьте правильность введенных данных!!!'+#10#13+'Данные должны вводиться через запятую...');
end;

procedure TFrm.FormActivate(Sender: TObject);
begin
  RangMatrixEdt.SetFocus;
end;

procedure TFrm.BitBtn2Click(Sender: TObject);
var tList:TStringList;
    i:Integer;
begin
  tList:=TStringList.Create;
  try
    for i:=1 to u do
      tList.Text:=tList.Text+' '+StringGrid3.Cells[0, i];
      tList.SaveToFile('a.txt');
  finally
    tList.Free;
  end;
end;

end.


Добавлено через 3 минуты и 10 секунд
да и ещё при запуске Project1.dpr выдаёт ошибку, что нет файла Project1.res......
его в архиве нет
PM MAIL   Вверх
Rodman
Дата 26.4.2007, 14:50 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


CIO
****


Профиль
Группа: Участник
Сообщений: 6144
Регистрация: 7.5.2006
Где: Ukraine ⇛ Kyiv ci ty

Репутация: 26
Всего: 122



Код

unit Unit1;
interface
uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, StdCtrls, Grids, ExtCtrls, Buttons;
const
 n1=7;
 n2=7;
type matr=array [1..n1,1..n2] of real;
     V=array [1..n1] of real;
type
  TFrm = class(TForm)
    BitBtn1: TBitBtn;
    RangMatrixEdt: TLabeledEdit;
    EpsEdt: TLabeledEdit;
    InputGrd: TStringGrid;
    OutputGrd: TStringGrid;
    LblA: TLabel;
    LblB: TLabel;
    LabeledEdit1: TLabeledEdit;
    StringGrid1: TStringGrid;
    StringGrid2: TStringGrid;
    StringGrid3: TStringGrid;
    BitBtn2: TBitBtn;
    procedure FormCanResize(Sender: TObject; var NewWidth,
      NewHeight: Integer; var Resize: Boolean);
    procedure InputGrdSetEditText(Sender: TObject; ACol, ARow: Integer;
      const Value: String);
    procedure FormActivate(Sender: TObject);
    procedure BitBtn1Click(Sender: TObject);
    procedure Vvod_Matr(var mat:matr; var ur:integer; var S:V);
    procedure swop(var m1:matr;var m2:matr;u:integer);
    procedure Matrinvers(p,q:integer; m1:matr; var m2:matr; var ur:integer;var S:V);
    procedure Out_Matr(m:matr;u:integer);
    procedure BitBtn2Click(Sender: TObject);
  private
    { Private declarations }
  public
    { Public declarations }
  end;
var
  Frm: TFrm;
  Matr_Gl,Matr_Inv:matr;
  p,q,u:integer;
  S1:V;
implementation
uses math;  //Unit2 не нужен...

{$R *.dfm}
procedure TFrm.Vvod_Matr(var mat:matr; var ur:integer; var S:V);
var i,j: integer;
begin
 write('Skolko uravneniy ' );
 readln(ur);
 for i:=1 to StrToInt(RangMatrixEdt.Text) do
  for j:=1 to StrToInt(RangMatrixEdt.Text) do
      mat[i, j]:=StrToInt(InputGrd.Cells[j,i]);
 for i:=1 to StrToInt(RangMatrixEdt.Text) do
  s[i]:=StrToInt(outputGrd.cells[0, i]);
end;
procedure TFrm.Out_Matr(m:matr;u:integer);
var
 i,j:integer;
begin
 for i:=1 to u do
  for j:=1 to u do
    StringGrid1.Cells[j,i]:=FloatToStr(m[i,j]);
end;
procedure TFrm.swop(var m1:matr;var m2:matr;u:integer);
 var
  i,j:integer;
  buf:real;
begin
 for i:=1 to u do
  for j:=1 to u do
  begin
     buf:=m1[i,j];
     m1[i,j]:=m2[i,j];
     m2[i,j]:=buf;
  end;
end;
procedure TFrm.Matrinvers(p,q:integer; m1:matr; var m2:matr; var ur:integer;var S:V);
var i,j: integer;
begin
 for i:=1 to ur do
  for j:=1 to ur do
   begin
     m2[i,j]:=m1[i,j]-((m1[i,p]*m1[q,j])/m1[q,p]);
     if j=p then m2[i,j]:=0;
     if i=q then m2[q,j]:=m1[q,j];
   end;
 for i:=1 to n2 do begin
  if i=q then  S[i]:=S[q] else
  S[i]:=S[i]-((m1[i,p]*S[q])/m1[q,p]);
 end;
end;
procedure TFrm.BitBtn1Click(Sender: TObject);
var i:Integer;
begin
  Vvod_Matr(Matr_Gl,u,S1);
  q:=StrToInt(EpsEdt.text);
  p:=StrToInt(LabeledEdit1.text);
  Matrinvers(p,q,Matr_Gl,Matr_Inv,u,S1);
  swop(Matr_Gl,Matr_Inv,u);
  Out_Matr(Matr_Gl,u);
  for i:=1 to u do
    StringGrid2.Cells[0, i]:=FloatToStr(S1[i]);
  for i:=1 to u do
    StringGrid3.Cells[0, i]:=FloatToStr(S1[i]/Matr_Gl[i,i]);
end;
procedure TFrm.FormCanResize(Sender: TObject; var NewWidth,
  NewHeight: Integer; var Resize: Boolean);
begin
  Resize:=false;
end;
procedure TFrm.InputGrdSetEditText(Sender: TObject; ACol,
  ARow: Integer; const Value: String);
var floatC:Double;
begin
  if(TryStrToFloat(InputGrd.Cells[ACol, ARow], floatC)=False)then
    ShowMessage('Проверьте правильность введенных данных!!!'+#10#13+'Данные должны вводиться через запятую...');
end;
procedure TFrm.FormActivate(Sender: TObject);
begin
  RangMatrixEdt.SetFocus;
end;
procedure TFrm.BitBtn2Click(Sender: TObject);
var tList:TStringList;
    i:Integer;
begin
  tList:=TStringList.Create;
  try
    for i:=1 to u do
      tList.Text:=tList.Text+' '+StringGrid3.Cells[0, i];
      tList.SaveToFile('a.txt');
  finally
    tList.Free;
  end;
end;
end.

Цитата(geniy @  26.4.2007,  13:24 Найти цитируемый пост)
нет файла Project1.res......

это не смертельно, Делфя сама создаст его... при запросе жди "Да"..

PM MAIL WWW Skype GTalk YIM MSN   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Центр помощи"

ВНИМАНИЕ! Прежде чем создавать темы, или писать сообщения в данный раздел, ознакомьтесь, пожалуйста, с Правилами форума и конкретно этого раздела.
Несоблюдение правил может повлечь за собой самые строгие меры от закрытия/удаления темы до бана пользователя!


  • Название темы должно отражать её суть! (Не следует добавлять туда слова "помогите", "срочно" и т.п.)
  • При создании темы, первым делом в квадратных скобках укажите область, из которой исходит вопрос (язык, дисциплина, диплом). Пример: [C++].
  • В названии темы не нужно указывать происхождение задачи (например "школьная задача", "задача из учебника" и т.п.), не нужно указывать ее сложность ("простая задача", "легкий вопрос" и т.п.). Все это можно писать в тексте самой задачи.
  • Если Вы ошиблись при вводе названия темы, отправьте письмо любому из модераторов раздела (через личные сообщения или report).
  • Для подсветки кода пользуйтесь тегами [code][/code] (выделяйте код и нажимаете на кнопку "Код"). Не забывайте выбирать при этом соответствующий язык.
  • Помните: один топик - один вопрос!
  • В данном разделе запрещено поднимать темы, т.е. при отсутствии ответов на Ваш вопрос добавлять новые ответы к теме, тем самым поднимая тему на верх списка.
  • Если вы хотите, чтобы вашу проблему решили при помощи определенного алгоритма, то не забудьте описать его!
  • Если вопрос решён, то воспользуйтесь ссылкой "Пометить как решённый", которая находится под кнопками создания темы или специальным флажком при ответе.

Более подробно с правилами данного раздела Вы можете ознакомится в этой теме.

Если Вам помогли и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, Poseidon, Rodman

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Центр помощи | Следующая тема »


 




[ Время генерации скрипта: 0.0842 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.