Что такое findslide.org?

FindSlide.org - это сайт презентаций, докладов, шаблонов в формате PowerPoint.


Для правообладателей

Обратная связь

Email: Нажмите что бы посмотреть 

Яндекс.Метрика

Презентация на тему Динамические переменные

Содержание

Объект данных обладает динамической структурой, если его размер изменяется в процессе выполнения программы или он потенциально бесконечен.Классификация структур данныхИспользуемые в программировании данные можно разделить на две большие группы:
15.11.2018 г тема урока :Динамические структуры данных.Подготовила учитель информатики:Радова А.Ф.Теоретический молдо-турецкий лицей им.С.ДемиреляС.Конгаз Объект данных обладает динамической структурой, если его размер изменяется в процессе выполнения Данные статической структуры – это данные, взаиморасположение и взаимосвязи элементов которых всегда Статические и динамические переменные в ПаскалеВ Паскале одной из задач описания типов Динамическая память (ДП) – это оперативная память ПК, предоставляемая программе при ее ДП – это фактически единственная возможность обработки массивов данных большой размерности. Многие Для работы с динамическими переменными в программе должны быть выполнены следующие действия:•	Выделение УказателиДля работы с динамическими программными объектами в Паскале предусмотрен ссылочный тип или Объявление указателейУказатель, связанный с некоторым определенным типом данных, называют типизированным указателем. Его Указатель, не связанный с каким-либо конкретным типом данных, называется нетипизированным указателем. Для Выделение памяти под динамическую переменную осуществляется процедурой: Освобождение динамической памяти осуществляется процедурой: Операции с указателямиДля указателей определены только операции присваивания и проверки на равенство В Паскале определены стандартные функции для работы с указателями:•	addr( x) – тип Динамические структурыСписком называется структура данных, каждый элемент которой посредством указателя связывается со Описание списка:Type ukazat= ^ S;  S= record   Inf: integer; Формирование списка:Чтобы список существовал, надо определить указатель на его начало.Type ukazat= ^S; Продолжим формирование списка. Для этого нужно добавить элемент либо в конец списка, New( x^. next); {выделяем память для следующего элемента}x:= x^.next; x^.next:= nil; x^. inf:= 5; hv:=x; Просмотр списка:While u nil doBeginWriteln (u^.inf);u:= u^.next;>end; Удаление элемента из спискаА)Удаление первого элемента. Для этого во вспомогательном указателе запомним Б) Удаление элемента из середины списка. Для этого нужно знать адреса удаляемого Прохождение списка. Важно уметь перебирать элементы списка, выполняя над ними какую-либо операцию. •	Стек – особый вид списка, обращение к которому идет только через указатель
Слайды презентации

Слайд 2 Объект данных обладает динамической структурой, если его размер

Объект данных обладает динамической структурой, если его размер изменяется в процессе

изменяется в процессе выполнения программы или он потенциально бесконечен.
Классификация

структур данных
Используемые в программировании данные можно разделить на две большие группы:


Слайд 3 Данные статической структуры – это данные, взаиморасположение и

Данные статической структуры – это данные, взаиморасположение и взаимосвязи элементов которых

взаимосвязи элементов которых всегда остаются постоянными.
Данные динамической структуры –

это данные, внутреннее строение которых формируется по какому-либо закону, но количество элементов, их взаиморасположение и взаимосвязи могут динамически изменяться во время выполнения программы, согласно закону формирования.


Слайд 5 Статические и динамические переменные в Паскале
В Паскале одной

Статические и динамические переменные в ПаскалеВ Паскале одной из задач описания

из задач описания типов является то, чтобы зафиксировать на

время выполнения программы размер значений, а, следовательно, и размер выделяемой области памяти для них. Описанные таким образом переменные называются статическими.
Все переменные, объявленные в программе, размещаются в одной непрерывной области оперативной памяти – сегмент данных. Длина сегмента данных определяется архитектурой микропроцессора и составляет обычно 65536 байт.


Слайд 6
Динамическая память (ДП) – это оперативная память ПК,

Динамическая память (ДП) – это оперативная память ПК, предоставляемая программе при

предоставляемая программе при ее работе, за вычетом сегмента данных

(64 Кб), стека (16 Кб) и собственно тела программы. Размер динамической памяти можно варьировать.



По умолчанию ДП – вся доступная память ПК.

Слайд 7 ДП – это фактически единственная возможность обработки массивов

ДП – это фактически единственная возможность обработки массивов данных большой размерности.

данных большой размерности. Многие практические задачи трудно или невозможно

решить без использования ДП.

И статические и динамические переменные вызываются по их адресам. Без адреса не получить доступа к нужной ячейке памяти, но при использовании статических переменных, адрес непосредственно не указывается. Обращение осуществляется по имени. Компилятор размещает переменные в памяти и подставляет нужные адреса в коды команд.
Адресация динамических переменных осуществляется через указатели. Их значения определяют адрес объекта.


Слайд 8 Для работы с динамическими переменными в программе должны

Для работы с динамическими переменными в программе должны быть выполнены следующие

быть выполнены следующие действия:
• Выделение памяти под динамическую переменную;

• Инициализация указателя;

• Освобождение

памяти после использования динамической переменной.

Программист должен сам резервировать место, определять значение указателей, освобождать ДП.
Вместо любой статической переменной можно использовать динамическую, но без реальной необходимости этого делать не стоит.


Слайд 9 Указатели
Для работы с динамическими программными объектами в Паскале

УказателиДля работы с динамическими программными объектами в Паскале предусмотрен ссылочный тип

предусмотрен ссылочный тип или тип указателей. В переменной ссылочного

типа хранится ссылка на программный объект (адрес объекта).
Указатель – это переменная, которая в качестве своего значения содержит адрес байта памяти.


Слайд 10 Объявление указателей
Указатель, связанный с некоторым определенным типом данных,

Объявление указателейУказатель, связанный с некоторым определенным типом данных, называют типизированным указателем.

называют типизированным указателем. Его описание имеет вид:

Имя_переменной: ^ базовый-тип;
Например:

Пример фрагмента программы объявления указателя:
Type A= array [1..100] of integer;
TA= ^ A ; {тип указатель на массив}
Var
P1: ^ integer; {переменная типа указатель на
целое число}
P2: ^ real; {переменная типа указатель на
вещественное число}


Слайд 11 Указатель, не связанный с каким-либо конкретным типом данных,

Указатель, не связанный с каким-либо конкретным типом данных, называется нетипизированным указателем.

называется нетипизированным указателем.
Для описания нетипизированного указателя в Паскале

существует стандартный тип pointer. Описание такого указателя имеет вид:
Имя-переменной: pointer;
С помощью нетипизированных указателей удобно динамически размещать данные, структура и тип которых меняются в ходе выполнения программы.
Значения указателей – это адреса переменных в памяти. Адрес занимает четыре байта и хранится в виде двух слов, одно из которых определяет сегмент, второе – смещение.


Слайд 12 Выделение памяти под динамическую переменную осуществляется процедурой:

Выделение памяти под динамическую переменную осуществляется процедурой:

New (переменная_типа_указатель)
В результате обращения к этой процедуре указатель получает значение, соответствующее адресу в динамической памяти, начиная с которого можно разместить данные.
Пример фрагмента программы объявления указателя различных типов:
Var i, j: ^integer;
r: ^real;
begin
new( i);
……………
new( r) ;
Графически действие процедуры new можно изобразить так:


Слайд 13 Освобождение динамической памяти осуществляется процедурой:

Освобождение динамической памяти осуществляется процедурой:     Dispose (переменная_типа_указатель);Пример

Dispose (переменная_типа_указатель);
Пример фрагмента программы

процедуры Dispose:
Dispose (i);
Dispose (r);
Следует помнить, что повторное применение процедуры dispose к свободному указателю может привести к ошибке.
Процедура dispose освобождает память, занятую динамической переменной. При этом значение указателя становится неопределенным.



Слайд 14 Операции с указателями
Для указателей определены только операции присваивания

Операции с указателямиДля указателей определены только операции присваивания и проверки на

и проверки на равенство и неравенство. В Паскале запрещаются

любые арифметические операции с указателями, их ввод-вывод и сравнение на больше-меньше.
Правила присваивания указателей:
• любому указателю можно присвоить стандартную константу nil, которая означает, что указатель не ссылается на какую-либо конкретную ячейку памяти;
• указатели стандартного типа pointer совместимы с указателями любого типа;
• указателю на конкретный тип данных можно присвоить только значение указателя того же или стандартного типа данных.
Указатели можно сравнивать на равенство и неравенство, например:
If p1=p2 then …..
If p1<>p2 then …..



Слайд 15 В Паскале определены стандартные функции для работы с

В Паскале определены стандартные функции для работы с указателями:•	addr( x) –

указателями:
• addr( x) – тип результата pointer, возвращает адрес x

(аналогично операции @), где x – имя переменной или подпрограммы;
• seg( x) – тип результата word, возвращает адрес сегмента для x;
• ofs( x) – тип результата word, возвращает смещение для x;
• ptr( seg, ofs) – тип результата pointer, по заданному сегменту и смещению формирует адрес типа pointer.


Слайд 16 Динамические структуры
Списком называется структура данных, каждый элемент которой

Динамические структурыСписком называется структура данных, каждый элемент которой посредством указателя связывается

посредством указателя связывается со следующим элементом.
Каждый элемент связанного списка,

во-первых, хранит какую-либо информацию, во-вторых, указывает на следующий за ним элемент. Так как элемент списка хранит разнотипные части (хранимая информация и указатель), то его естественно представить записью, в которой в одном поле располагается объект, а в другом – указатель на следующую запись такого же типа. Такая запись называется звеном, а структура из таких записей называется списком или цепочкой.
Лишь на самый первый элемент списка (голову) имеется отдельный указатель. Последний элемент списка никуда не указывает.


Слайд 17 Описание списка:
Type ukazat= ^ S;
S= record

Описание списка:Type ukazat= ^ S; S= record  Inf: integer;

Inf: integer;
Next: ukazat;

End;
В Паскале существует основное правило: перед использованием какого-либо объекта он должен быть описан. Исключение сделано лишь для указателей, которые могут ссылаться на еще не объявленный тип.

Слайд 18 Формирование списка:
Чтобы список существовал, надо определить указатель на

Формирование списка:Чтобы список существовал, надо определить указатель на его начало.Type ukazat=

его начало.
Type ukazat= ^S;
S= record

Inf: integer;
Next: ukazat;
End;
Создадим первый элемент списка:
New (u); {выделяем место в памяти}
u^. Next:= nil; {указатель пуст}
u^. Inf:=3;


Слайд 19 Продолжим формирование списка. Для этого нужно добавить элемент

Продолжим формирование списка. Для этого нужно добавить элемент либо в конец

либо в конец списка, либо в голову.
А) Добавим элемент

в голову списка. Для этого необходимо выполнить последовательность действий:
• получить память для нового элемента;
• поместить туда информацию;
• присоединить элемент к голове списка.
New(x);
Readln(x^.Inf);
x^. Next:= u;
u:= x;
Б)Добавление элемента в конец списка. Для этого введем вспомогательную переменную, которая будет хранить адрес последнего элемента. Пусть это будет указатель с именем hv (хвост).
x:= hv;


Слайд 20 New( x^. next); {выделяем память для следующего элемента}
x:=

New( x^. next); {выделяем память для следующего элемента}x:= x^.next; x^.next:= nil; x^. inf:= 5; hv:=x;

x^.next;
x^.next:= nil;
x^. inf:= 5;
hv:=x;


Слайд 21 Просмотр списка:
While u nil do
Begin
Writeln (u^.inf);
u:= u^.next;>
end;

Просмотр списка:While u nil doBeginWriteln (u^.inf);u:= u^.next;>end;

Слайд 22 Удаление элемента из списка
А)Удаление первого элемента. Для этого

Удаление элемента из спискаА)Удаление первого элемента. Для этого во вспомогательном указателе

во вспомогательном указателе запомним первый элемент, указатель на голову

списка переключим на следующий элемент списка и освободим область динамической памяти, на которую указывает вспомогательный указатель.
x:= u;
u:= u^.next;
dispose(x);


Слайд 23 Б) Удаление элемента из середины списка. Для этого

Б) Удаление элемента из середины списка. Для этого нужно знать адреса

нужно знать адреса удаляемого элемента и элемента, стоящего перед

ним. Допустим, что digit – это значение удаляемого элемента.
x:= u;
while ( x<> nil) and ( x^. inf<> digit) do
begin
dx:= x;
x:= x^.next;
end;
dx:= x^.next:
dispose(x);
В)Удаление из конца списка. Для этого нужно найти предпоследний элемент.
x:= u; dx:= u;
while x^.next<> nil do
begin
dx:= x; x:= x^.next;
end;
dx^.next:= nil;
dispose(x);


Слайд 24 Прохождение списка.
Важно уметь перебирать элементы списка, выполняя

Прохождение списка. Важно уметь перебирать элементы списка, выполняя над ними какую-либо

над ними какую-либо операцию. Пусть необходимо найти сумму элементов

списка.
summa:= 0;
x:= u;
while x<> nil do
begin
summa:= summa+ x^.inf;
x:= x^.next;
end;


  • Имя файла: dinamicheskie-peremennye.pptx
  • Количество просмотров: 144
  • Количество скачиваний: 0