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

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

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

 
 Ответить  Открыть новую тему 
> Предок и потомок ООП, Помогите добавить предка и потомка
Jarj
сообщение 25.12.2014 12:42
Сообщение #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 - 25.12.2014 12:43
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
Федосеев Павел
сообщение 25.12.2014 22:29
Сообщение #2


Бывалый
***

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

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


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

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

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

 



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