Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Начинающим";
Текущий архив: 2007.11.18;
Скачать: [xml.tar.bz2];

Вниз

Передача двумерного массива в метод класса.   Найти похожие ветки 

 
Sin ©   (2007-10-24 09:25) [0]

Подобный вопрос обсуждался http://delphimaster.net/view/2-1191862496/, однако хотелось бы узнать можно ли передать двумерный массив в класс расположенный в другом unit"е.


 
MBo ©   (2007-10-24 09:28) [1]

конечно, можно


 
Сергей М. ©   (2007-10-24 09:28) [2]

Можно.


 
Сергей М. ©   (2007-10-24 09:29) [3]

Причем по барабану мерность массива и местонахождение декларации класса.


 
Sin ©   (2007-10-24 09:31) [4]

Может подскажете как, при условии массив должен быть динамическим.


 
Sin ©   (2007-10-24 09:32) [5]

У меня появляется несоответствие Array and Dynamic array.


 
Kolan ©   (2007-10-24 09:33) [6]

> Может подскажете как

TMyMatrix = array of array of Integer;

procedure Proc(Arr: TMyMatrix);


?


 
Sin ©   (2007-10-24 10:09) [7]

Спасибо, получилось. Поскажите еще, пожалуйсто, как в этом случае можно "вернуть" одномерный массив. Что-то уменя ошибка появляется...
// класс
type
 TArray    = array of double;
 TMyMatrix = array of TArray;

 MyClass = class
 private
 public
   function MySum(N: integer; mas: TMyMatrix): TArray;
 end;

implementation

function MyClass.MySum(N: integer; mas: TMyMatrix): TArray;
 var
   i,j : integer;
   sum : double;
begin
{  SetLength(MySum,N);} // нужно ли это делать???
 for i := 0 to N do
   begin
   sum := 0;
   for j := 0 to N do sum := sum + mas[i,j];
   MySum[i] := sum; // здесь ошибка...
   end;
end;

// программа
procedure TForm1.Button1Click(Sender: TObject);
 var
   a : TArray;
   b : integer;
   c : TMyMatrix;
begin
 b := 2;
 SetLength(c,2,2);
 c[0,0] := 1;
 c[0,1] := 2;
 c[1,0] := 1;
 c[1,1] := 2;
 a := t.MySum(b,c);
end;


 
Сергей М. ©   (2007-10-24 10:21) [8]

function MyClass.MySum(N: integer; mas: TMyMatrix): TArray;
var
  i,j : integer;
  sum : double;
begin
SetLength(Result, N);} // нужно !!!!!
for i := 0 to N - 1 do
begin
  sum := 0;
  for j := 0 to N - 1 do
    sum := sum + mas[i,j];
  Result[i] := sum;
end;
end;


 
Sin ©   (2007-10-24 10:23) [9]

;) СПАСИБО!



Страницы: 1 вся ветка

Форум: "Начинающим";
Текущий архив: 2007.11.18;
Скачать: [xml.tar.bz2];

Наверх





Память: 0.46 MB
Время: 0.042 c
15-1192398990
Petr V. Abramov
2007-10-15 01:56
2007.11.18
как запрораммировать на Delphi


6-1174036472
salexn
2007-03-16 12:14
2007.11.18
TSocketConnection и плохая сетка


15-1192710762
Сатир
2007-10-18 16:32
2007.11.18
Загрузка модулей, которые содержать компоненты DevExpress


2-1193400497
vajo
2007-10-26 16:08
2007.11.18
Нужно внести изменения в текстовом файле на сайте.


1-1188460255
Kolan
2007-08-30 11:50
2007.11.18
Disabled кнопка тулбара с Enabled выпадающим списком, возможно?





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский