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

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

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

 
 Ответить  Открыть новую тему 
> Предок и потомок ООП, Помогите добавить предка и потомка
сообщение
Сообщение #1





Группа: Пользователи
Сообщений: 2
Пол: Мужской

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


Помогите добавить предка и потомка

 program Project1;

{$APPTYPE CONSOLE}

uses
SysUtils;

const
nmax = 20;

type
TArray = object
A : array [1..nmax] of integer;
procedure Init;
procedure Enter (n : integer);
function FindMax (i, j : integer) : integer;
procedure Change (i, j : integer);
procedure Print (n : integer);

end;

procedure TArray.Init;
begin
end;

procedure TArray.Enter (n : integer);
var
i : integer;
begin
for i := 1 to n do
begin
Write('A[', i, '] = ');
Readln(A[i]);
end;
end;

procedure TArray.Print (n : integer);
var
i : integer;
begin
for i := 1 to n do
Write(A[i], ' ');
end;

function TArray.FindMax (i, j : integer) : integer;
var
k : integer;
max : integer;
begin
max := A[i];
for k := i + 1 to j do
if A[k] > max then max := A[k];
FindMax := max;
end;

procedure TArray.Change (i, j : integer);
var
temp : integer;
begin
temp := A[i];
A[i] := A[j];
A[j] := temp;
end;

var
B : TArray;
n, start, finish, j, k : integer;

begin
B.Init;
Repeat
Write('Razmer massiva: ');
Readln(n);
until n in [1..nmax];
Writeln('Vvedite massiv: ');
B.Enter(n);
Repeat
Write('vvod 2 number: ');
Readln(start, finish);
until start <= finish;
Writeln('max mejdu elementami: ', B.FindMax (start, finish));
Write('obmen 2 nomera: ');
Readln(j, k);
Writeln('new massiv: ');
B.Change(j, k);
B.Print(n);
Readln;
end.


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


Знаток
****

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

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


Я не совсем понял вопрос. Если тебе нужны идеи, то
предок - какой нибудь абстрактный тип с методами ввода/вывода но без хранилища (без массива).
потомок - сортированный массив - добавляются свойства Duplicate (удалять или нет одинаковые элементы).

По аналогии с типами (классами) TList, TStringList - если я ничего не путаю.
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 

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

 





- Текстовая версия 2.05.2024 17:19
500Gb HDD, 6Gb RAM, 2 Cores, 7 EUR в месяц — такие хостинги правда бывают
Связь с администрацией: bu_gen в домене octagram.name