Сложные структуры данных

Содержание

Слайд 2

Массивы

- упорядоченные множества элементов одного типа, занимающих непрерывное пространство в памяти

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

Слайд 3

X = {xij: a≤i≤b и c≤j≤d}
xa,c xa,c+1 … xa,d-1 xa,d xa+1,c xa+1,c+1 … xa+1,d-1 xa+1,d … xij … xb-1,c xb-1,c+1 … xb-1,d-1 xb-1,d xb,c xb,c+1 … xb,d-1 xb,d

X = {xij: a≤i≤b и c≤j≤d} xa,c xa,c+1 … xa,d-1 xa,d xa+1,c

Слайд 4

Расположение в памяти

По строкам:
xa,c xa,c+1 … xa,d-1 xa,d xa+1,c xa+1,c+1 … xa+1,d-1

Расположение в памяти По строкам: xa,c xa,c+1 … xa,d-1 xa,d xa+1,c xa+1,c+1
xa+1,d … xa+1,c xa+1,c+1 … xa+1,d-1 xa+1,d xb,c xb,c+1 … xb,d-1 xb,d
По столбцам:
xa,c xa+1,c … xb-1,c xb,c xa,c+1 xa+1,c+1 … xb-1,c+1 xb,c+1 … xa,d-1 xa+1,d-1 … xb-1,d-1 xb,d-1 xa,d xa+1,d … xb-1,d xb,d

Быстый последний индекс

Быстрый первый индекс

X+((i-a)*(d–c+1) + j-c)*Type X

X+((j-c)*(b–a+1) + i-a)*Type X

Слайд 5

Строки переменной длины

Си
String db ‘Это строка С’,0
Паскаль
String db Len-1,‘Строка Паскаля’ Len = $

Строки переменной длины Си String db ‘Это строка С’,0 Паскаль String db
- String

Произвольная длина
Длину необходимо вычислять

Длина не более 255
Длина всегда известна без вычислений

Слайд 6

Перечислимые типы данных

Azb enum a,b,c,d,e,f,g,h,i,j,k,l,n,m,o,p,q,r,s,t,v,u,w,x,y,z ; a=0, b=1, … , z=25
Azb enum a=61h,b,c,… ;

Перечислимые типы данных Azb enum a,b,c,d,e,f,g,h,i,j,k,l,n,m,o,p,q,r,s,t,v,u,w,x,y,z ; a=0, b=1, … , z=25
a=61h, b=62h, …
mov al,azb ; al=31

Число бит, необходимых для представления множества, с перечисленным числом компонент

Слайд 7

Множество

совокупность элементов, обладающих общим для них характеристическим свойством.
конечная упорядоченная совокупность элементов, т.е.

Множество совокупность элементов, обладающих общим для них характеристическим свойством. конечная упорядоченная совокупность
каждому элементу поставлено в соответствие натуральное число, являющееся номером элемента множества.
Множество можно моделировать набором бит в количестве равном числу элементов множества, когда значение i-ого бита отвечает наличию или отсутствию i–ого элемента в множестве.
Для множества мощностью n требуется n/8+1 байт

Слайд 8

Setof macro name,pw,x rr=pw/8 if pw mod 8 ne 0 rr=rr+1 endif if rr eq 1
name label byte elseif rr eq

Setof macro name,pw,x rr=pw/8 if pw mod 8 ne 0 rr=rr+1 endif
2
name label word elseif rr le 4
name label dword elseif rr le 8
name label qword else

Выделение места для размещения множества

Слайд 9

.err "Не могу создать множество такого размера“ exitm endif kk=0 while kk lt rr

.err "Не могу создать множество такого размера“ exitm endif kk=0 while kk
shablon=0 irp i, if i/8 eq kk shablon=shablon or (1 shl (i mod 8)) endif endm db shablon kk=kk+1 endm endm

Слайд 10

Сегмент данных

.data
Alphabet enum A,B,C,D,E,F,G,H,I,J,K,L,N,M,O,P,Q,R,S,T,V,U,W,X,Y,Z
SETOF VOWELS,Alphabet,
SETOF CONSONANTS,Alphabet,

Сегмент команд

.code jnc short no main proc beepspkr mov

Сегмент данных .data Alphabet enum A,B,C,D,E,F,G,H,I,J,K,L,N,M,O,P,Q,R,S,T,V,U,W,X,Y,Z SETOF VOWELS,Alphabet, SETOF CONSONANTS,Alphabet, Сегмент команд
ax,@data no: .exit 0 mov ds,ax main endp inmn VOWELS,B end main

Слайд 11

Проверка присутствия элемента в множестве

Inmn macro name,k ;; Результат в fc ifndef .err ‘Имя &name

Проверка присутствия элемента в множестве Inmn macro name,k ;; Результат в fc
не определено‘ exitm elseifndef .err ‘Имя &k не определено‘ exitm endif if k gt (type name)*8 clc exitm endif

push ax push bx mov ax,k ror ax,3 shr ah,5 ;; ah=номер бита, ;; al=номер байта mov bl,al xor bh,bh mov bl,byte ptr name[bx] shr ax,8 bts bx,ax pop bx pop ax endm

Слайд 12

Вспомогательный макрос

beepspkr macro times:=<1>
push ax
push dx
mov ah,2
mov dl,7
rept times
int 21h
endm
pop dx
pop ax
endm

Вспомогательный макрос beepspkr macro times:= push ax push dx mov ah,2 mov

Слайд 13

Записи

наборы групп битовых полей внутри байта, слова или двойного слова.
Формат описания шаблона: Имя_шаблона

Записи наборы групп битовых полей внутри байта, слова или двойного слова. Формат
RECORD айтем[,айтем…]
Например:
День Месяц Год

Имя:длина[=значение по умолчанию]

15

14

13

12

11

10

9

8

7

6

5

4

3

2

1

0

Date_format record day:5=1,month:4=1,year:7=0

Константа равная сдвигу поля от правого края

0

7

11

Слайд 14

Описание переменных типа запись

Test_date Date_format <7,5,4>
Millennium Date_format <>
Yesterday Date_format {year =4,month=4}

Операторы работы с записями

Mask имя_поля mov ax,mask year ;

Описание переменных типа запись Test_date Date_format Millennium Date_format Yesterday Date_format {year =4,month=4}
ax = 007fh
Width имя_поля mov ax,width month ; ax = 4

Getfild getfild month bl,test_date
Setfild
and test_date,not mask month mov bx,6 setfild month test_date,6

mov ax,test_date
and ax,mask month
shr ax,month

And test_date,not mask month
Or test_date,6 shl month

Слайд 15

Структуры

совокупности переменных различного типа.
Формат описания шаблона структуры: Имя_шаблона struc Описатель переменной [ … Описатель переменной] Имя_шаблона ends
Например: Complex struc Re dd 0. Im dd 0. Complex ends

Имена переменных – константы,

Структуры совокупности переменных различного типа. Формат описания шаблона структуры: Имя_шаблона struc Описатель
характеризующие расстояние поля от начала структуры в байтах

Mov ax,type complex.re ; ax = 4 Mov ax,type complex ; ax = 8

Слайд 16

Описание переменных формата структура

Cnul complex <>
Ced complex <1.,>
Ci complex {im=1.0}
Carray complex 10 dup

Доступ к полям структуры

Прямая адресация Mov eax,Cnul.Re mov Cnul.Im,eax

Косвенная

Описание переменных формата структура Cnul complex Ced complex Ci complex {im=1.0} Carray
адресация Mov bx,offset Ci Mov eax,[bx].Im

Слайд 17

Объединения

наложение переменных различного типа.
Формат описания шаблона объединения: Имя_шаблона Union описатель переменной [ … описатель переменной] Имя_шаблона ends
Правила работы те же,

Объединения наложение переменных различного типа. Формат описания шаблона объединения: Имя_шаблона Union описатель
что и со структурами
Другой способ – использование директивы Имя LABEL тип

Слайд 18

Списки

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

Списки совокупность элементов типа структура, расположенных в произвольных местах памяти, связанных друг
другом через поля связи – переменные в которых хранятся ссылки (адреса) на следующий элемент.
Последний элемент списка (не связанный с другими) хранит в таком поле пустую ссылку, называемую nil.
Ссылка на первый элемент списка хранится в переменной, которую называют указателем на вершину списка.

Слайд 19

Примерный формат элемента списка (aitem).

filds struc fild1 dw ? … filds ends

Aitem struc list filds <> next dw ?
Aitem ends

Примерный формат элемента списка (aitem). filds struc fild1 dw ? … filds

Слайд 20

Пример устройства «диспетчера» кучи

.model small
.386
nil = -1
Heap_size = 64*1024
filds struc
fild1 db 8 dup(?)
fild2 db ?
filds ends
aitem struc
list filds <>
next dw ?
aitem ends

Пример устройства «диспетчера» кучи .model small .386 nil = -1 Heap_size =

Слайд 21

Пример устройства «диспетчера» кучи

.data
Status db Heap_size/8 dup(0)
top dw ?
str1 db 'String 1'
str2 db 'String 2'
str3 db 'String 3'
.stack 256
Heap segment para
Htop db Heap_size dup(?) ; Куча
Heap ends
.code

Пример устройства «диспетчера» кучи .data Status db Heap_size/8 dup(0) top dw ?

Слайд 22

Создание нового элемента списка

new macro size
ifndef Heap
.err
exitm
elseifndef Status
.err
exitm
endif
mov ax,size ; Размер искомого свободного

Создание нового элемента списка new macro size ifndef Heap .err exitm elseifndef
участка
call find
endm

Слайд 23

Удаление элемента списка

Delite macro adr,size mov bx,adr ; Адрес освобождаемой памяти в bx mov cx,size ; Размер освобождаемой

Удаление элемента списка Delite macro adr,size mov bx,adr ; Адрес освобождаемой памяти
области call clear endm
Start macro assume es:Heap mov ax,@data mov ds,ax mov ax,Heap mov es,ax xor ax,ax endm

Слайд 24

Сохранение и загрузка регистров

SaveReg macro r1,r2,r3,r4,r5,r6,r7,r8,r9 ifnb push r1 SaveReg r2,r3,r4,r5,r6,r7,r8,r9 endif endm
 LoadReg macro r1,r2,r3,r4,r5,r6,r7,r8,r9 irp

Сохранение и загрузка регистров SaveReg macro r1,r2,r3,r4,r5,r6,r7,r8,r9 ifnb push r1 SaveReg r2,r3,r4,r5,r6,r7,r8,r9
k, ifnb pop k endif endm endm

Слайд 25

Основная программа

main proc
.Start new %type aitem ; Найти подходящую область памяти для ; размещения элемента списка mov top,ax ; Указатель

Основная программа main proc .Start new %type aitem ; Найти подходящую область
на вершину списка
; Первый элемент mov bx,ax mov cx,8 lea si,str1 lea di,[bx].list.fild1 rep movsb ;заполнение поля fild1 первого элемента new %type aitem mov es:[bx].next,ax ; адрес второго элемента mov es:[bx].list.fild2,'$'

Слайд 26

Создание 2 и 3 элементов

mov bx,ax mov cx,8 lea si,str2 lea di,[bx].list.fild1 rep movsb ;заполнение поля fild1 второго элемента new %type aitem mov es:[bx].next,ax ; адрес третьего

Создание 2 и 3 элементов mov bx,ax mov cx,8 lea si,str2 lea
элемента mov es:[bx].list.fild2,'$'
mov bx,ax mov cx,8 lea si,str3 lea di,[bx].list.fild1 rep movsb ;заполнение поля fild1 третьего элемента mov es:[bx].next,nil ; конец списка mov es:[bx].list.fild2,'$'

Слайд 27

Удаление элемента и печать списка

mov bx,top delite es:[bx].next,%type aitem mov bx,top mov di,es:[bx].next mov ax,es:[di].next mov es:[bx].next,ax
mov bx,top ; Адрес текущего элемента списка cont: cmp bx,nil jz fin ;

Удаление элемента и печать списка mov bx,top delite es:[bx].next,%type aitem mov bx,top
достигнут конец списка lea dx,[bx].list.fild1 push ds push es pop ds mov ah,09h int 21h ;Печать тестового поля текущего элемента pop ds mov bx,es:[bx].next jmp cont fin: .exit 0 main endp

Слайд 28

Процедура поиска места в куче

find proc ; ax - размер требующейся памяти в байтах SaveReg

Процедура поиска места в куче find proc ; ax - размер требующейся
bx,cx,dx mov cx,Heap_size/8 ; кол-во байт под статус mov bx,0 push ax ; сохранить объем памяти в стеке
m0: cmp status[bx],0ffh ; проверка на все единицы jz next1 mov dl,1 ; 1 в левый бит
m7: test status[bx],dl ; проверка бита jz m1 pop ax ; текущий бит равен 1 - заново push ax jmp short m2
m1: dec ax ; найден еще один нулевой бит
jz yes ; найден нужный объем памяти
m2: shl dl,1 ; маска для следующего бита jz m3 ; нужно перейти к новому байту jmp m7

Слайд 29

Процедура поиска места в куче

next1: pop ax ; восстановление размера push ax
m3: inc bx ; увеличение номера байта loop m0 ; цикл

Процедура поиска места в куче next1: pop ax ; восстановление размера push
по всем байтам jz no
yes: shl bx,3 ; вычисление номера последнего бита pop cx ; считан размер
m4: inc bx ; добавить сдвиг внутри байта shr dl,1 jnz m4 sub bx,cx ; номер первого бита поля mov ax,bx push a shr bx,3 ; номер байт and ax,07h ; и еще сдвиг на несколько бит mov ah,1 push cx mov cl,al shl ah,cl ; сдвиг маски в позицию первого бита

Слайд 30

Заполнение массива Status

pop cx
m6: or status[bx],ah ; заполнение 1 маски отводимого поля dec cx jz m5 shl ah,1 jnz m6 inc bx mov ah,1 jmp m6
no: mov ax,-1
m5: LoadReg bx,cx,dx,ax ret
find endp

Заполнение массива Status pop cx m6: or status[bx],ah ; заполнение 1 маски
Имя файла: Сложные-структуры-данных.pptx
Количество просмотров: 130
Количество скачиваний: 0