КАТЕГОРИИ: Архитектура-(3434)Астрономия-(809)Биология-(7483)Биотехнологии-(1457)Военное дело-(14632)Высокие технологии-(1363)География-(913)Геология-(1438)Государство-(451)Демография-(1065)Дом-(47672)Журналистика и СМИ-(912)Изобретательство-(14524)Иностранные языки-(4268)Информатика-(17799)Искусство-(1338)История-(13644)Компьютеры-(11121)Косметика-(55)Кулинария-(373)Культура-(8427)Лингвистика-(374)Литература-(1642)Маркетинг-(23702)Математика-(16968)Машиностроение-(1700)Медицина-(12668)Менеджмент-(24684)Механика-(15423)Науковедение-(506)Образование-(11852)Охрана труда-(3308)Педагогика-(5571)Полиграфия-(1312)Политика-(7869)Право-(5454)Приборостроение-(1369)Программирование-(2801)Производство-(97182)Промышленность-(8706)Психология-(18388)Религия-(3217)Связь-(10668)Сельское хозяйство-(299)Социология-(6455)Спорт-(42831)Строительство-(4793)Торговля-(5050)Транспорт-(2929)Туризм-(1568)Физика-(3942)Философия-(17015)Финансы-(26596)Химия-(22929)Экология-(12095)Экономика-(9961)Электроника-(8441)Электротехника-(4623)Энергетика-(12629)Юриспруденция-(1492)Ядерная техника-(1748) |
Удаление элемента из списка
End. Do Begin Var Begin Else End Begin Begin Begin Var Type Implementation Var Type Uses Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs, StdCtrls; TForm1 = class(TForm) Label1: TLabel; Label2: TLabel; Button1: TButton; Button2: TButton; Label3: TLabel; Edit1: TEdit; Edit2: TEdit; procedure ButtonlClick(Sender: TObject); procedure Button2Click(Sender: TObject); procedure FormActivate(Sender: TObject); private { Private declarations } public { Public declarations } end; Form1: TForm1; ($R *.DFM} TPStudent=ATStudent; //указатель на тип TStudent TStudent = record f_name:string[20]; // фамилия l_name:string[20]; // имя next: TPStudent; // следующий элемент списка end; head: TPStudent; // начало (голова) списка // добавить элемент в список procedure TForm1.Button1Click(Sender: TObject); var node: TPStudent; // новый узел списка curr: TPStudent; // текущий узел списка pre: TPStudent; // предыдущий, относительно curr, узел new(node); // создание нового элемента списка node^.f_name:=Edit1.Text; // фамилия node^.l_name:=Edit2.Text; // имя // добавление узла в список // сначала найдем в списке подходящее место для узла curr:=head; pre: =NIL; { Внимание! Если приведенное ниже условие заменить на (node. f_name>curr". f__name) and (currONIL), то при добавлении первого узла возникает ошибка времени выполнения, т. к. curr = NIL и, следовательно, переменной curr. *name нет! В используемом варианте условия ошибка не возникает, т. к. сначала проверяется условие (curr о NIL), значение которого FALSE, и второе условие в этом случае не проверяется. } while (curr о NIL) and (node.f_name > curr^.f_name) do // введенное значение больше текущего pre:= curr; curr:=curr^.next; // к следующему узлу end; if pre = NIL then // новый узел в начало списка node^. next: =head; head:=node; // новый узел после pre, перед curr node^.next:=рre^.next; рrе^.next:=node; end; Edit1.text:=''; Edit2.text:=''; Edit1.SetFocus; end; // отобразить список procedure TForm1.Button2Click(Sender: TObject); curr: TPStudent; // текущий элемент списка n:integer; // длина (кол-во элементов) списка at:string; // строковое представление списка n:=0; st: = ''; curr:=head; while curr <> NIL begin n:=n+l; st:=st+curr^.f_name+' '+currA.l_name+#13; curr:=curr^.next; end; if n <> 0 then ShowMessage('Список: '+ЦЗ+st) else ShowMessage('В списке нет элементов.'); end; // начало работы программы procedure TForm1.FormActivate(Sender: TObject); begin head:=NIL; // список пустой end; Процедура TFormi.ButtoniClick создает динамическую переменную-запись, присваивает ее полям значения, соответствующие содержимому полей ввода диалогового окна, находит подходящее место для узла и добавляет этот узел в список, корректируя при этом значение указателя узла next, после которого должен быть помещен новый узел. Рис. 85. Пример упорядоченного списка, сформированного программой Вывод списка выполняет процедура TForml.Button2Сlick, которая запускается нажатием кнопки Показать. После запуска программы и ввода нескольких фамилий, например, в такой последовательности: Иванов, Яковлев, Алексеев, петров, список выглядит так, как показано на рис. 85. Для того чтобы удалить узел, необходимо скорректировать значение указателя узла, который находится перед удаляемым узлом (рис. 86). Рис. 86. Удаление элемента из списка Поскольку узел является динамической переменной, то после исключения узла из списка занимаемая им память должна быть освобождена. Освобождение динамической памяти, или, как иногда говорят, "уничтожение переменной", выполняется вызовом процедуры dispose. У процедуры dispose один параметр — указатель на динамическую переменную. Память, занимаемая этой динамической переменной, должна быть освобождена. Например, в программе var р: ^integer;
Дата добавления: 2014-12-25; Просмотров: 388; Нарушение авторских прав?; Мы поможем в написании вашей работы! Нам важно ваше мнение! Был ли полезен опубликованный материал? Да | Нет |