![]() |
1. Заголовок темы должен быть информативным. В противном случае тема удаляется ...
2. Все тексты программ должны помещаться в теги [code=pas] ... [/code].
3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали!
4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора).
5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM!
6. Одна тема - один вопрос (задача)
7. Проверяйте программы перед тем, как разместить их на форуме!!!
8. Спрашивайте и отвечайте четко и по существу!!!
![]() |
Анна |
![]() ![]()
Сообщение
#1
|
![]() Бывалая ![]() ![]() ![]() Группа: Пользователи Сообщений: 290 Пол: Женский Реальное имя: Анютка Репутация: ![]() ![]() ![]() |
Почитала faq по ООП.
Все очень сложно ![]() ![]() Цитата Реализовать объект. Создать и вызвать несколько свойств и методов. Объект лучше графический. Если раннее сабж решался, то дайте линк. |
![]() ![]() |
Анна |
![]() ![]()
Сообщение
#2
|
![]() Бывалая ![]() ![]() ![]() Группа: Пользователи Сообщений: 290 Пол: Женский Реальное имя: Анютка Репутация: ![]() ![]() ![]() |
Есть мысль переделать программу Динамический список: добавление/удаление по номеру
Вот код: uses Crt;
type
PItem = ^Item;
Item = record
Name : string;
Next : PItem;
end;
var
TempNew,Temp,first : PItem;
i, k, n : integer;
key : char;
procedure ADD(k:integer);
begin
if k<=n+1 then
begin
new(Tempnew);
write('Vvedite Znachenie: ');
readln(Tempnew^.name);
writeln;
if k = 1 then
begin
Tempnew^.Next:=first;
First:=tempnew;
end;
if (k>1)and(k<=n) then
begin
Temp:=first;
for i:=1 to k-2 do Temp:=temp^.next;
Tempnew^.next:=temp^.next;
temp^.next:=tempnew;
end;
if k=n+1 then
begin
Temp:=first;
for i:=1 to n-1 do Temp:=temp^.next;
Temp^.next:=tempnew;
end;
inc(n);
end;
end;
procedure RESULT;
begin
Temp:=first;
for i:=1 to n do
begin
writeln(i,' eLement: ',temp^.name);
Temp:=Temp^.next;
end;
end;
procedure DEL(k1:integer);
begin
if k<=n then
begin
if (k>1)and(k<n) then
begin
Temp:=first;
for i:=1 to k-2 do Temp:=temp^.next;
tempnew:=temp;
Temp:=temp^.next;
tempnew^.next:=temp^.next;
end;
if k=n then
begin
Temp:=first;
for i:=1 to n-1 do Temp:=temp^.next;
end;
dispose(temp);
n:=n-1;
end;
end;
Begin
textattr:=green;
clrscr;
n:=0;
first:=nil;
repeat
writeln;
writeln(' [1] Dobavlenie'); writeln;
writeln (' [2] Udalenie'); writeln;
writeln ('[ESCl Exit'); writeln;
key:=readkey;
case key of
'1':begin
write('Vvedite nomer elementa: ');
readln(k);
ADD(k);
end;
'2':begin
write('Vvedite nomer elementa: ');
readln(k);
DEL(k);
end;
end;
RESULT;
until key=#27;
end.
|
![]() ![]() |
![]() |
Текстовая версия | 8.08.2025 7:43 |