Инструменты пользователя

Инструменты сайта


bb:redbook:207

Различия

Показаны различия между двумя версиями страницы.

Ссылка на это сравнение

Предыдущая версия справа и слева Предыдущая версия
Следующая версия
Предыдущая версия
bb:redbook:207 [2018/11/30 01:13]
127.0.0.1 внешнее изменение
bb:redbook:207 [2020/10/29 07:08] (текущий)
Строка 2: Строка 2:
  
 ==== 1. Понятие о связанном списке ==== ==== 1. Понятие о связанном списке ====
-Что такое список — знают все из повседневной жизни. Это лист бумаги, который содержит пункты, например, того, что нужно купить в магазине. Аналога связанного списка [1] в жизни нет. С большой натяжкой связанным списком в жизни можно назвать алгоритм схемы в виде блок-схем [2]. В блок-схемах каждый последующий блок, связан с предыдущим. но в блок-схемам могут быть побочные связи, а в связанных списках они встречаются довольно редко.+Что такое список — знают все из повседневной жизни. Это лист бумаги, который содержит пункты, например, того, что нужно купить в магазине. Аналога связанного списка  в жизни нет.((Связный список не единственная структура в подобном роде. Варианты списков можно посмотреть в Википедии. Если ей верить, то допустимо использование названий структуры как «Связный список», так и «Связанный список» (от слов «связной» и «связанный»). В сущности, название структуры бездумно, и наиболее подходящий объект из реальности для описания этого типа структуры -- цепь и её звенья.)) С большой натяжкой связанным списком в жизни можно назвать алгоритм схемы в виде блок-схем ((Блок-схема — это одна из технологий разработки программного обеспечения (ПО), которая была принята в качестве стандарта на заре компьютерной эпохи. Необходимость в блок-схемах естественно вытекала из-за невыразительности языков программирования. Очень часто в государственных организациях до наших дней можно встретить алгоритмы действий в виде блок-схем на стенах. Блок-схемы несколько архаичны, но например, такой визуальный графический язык, как ДРАКОН ещё не сказал своего слова. Создатели космического корабля «Буран» это подтверждают (см. [[ru.wikipedia.org/Буран|Википедию]]).)). В блок-схемах каждый последующий блок, связан с предыдущим. но в блок-схемам могут быть побочные связи, а в связанных списках они встречаются довольно редко.
  
-Связанный список, как и блок-схема, в каждом элементе списка содержит полезную информацию, и также содержит служебную информацию. Эта информация, может быть представлена указателем на следующий элемент, точно такой же по структуре. Такой список называется односвязным. Может быть в элементе указатель на предыдущую структуру. Такой список называется двусвязным. Могут быть ещё какие-то указатели на совсем другие структуры, по необходимости.+Связанный список, как и блок-схема, в каждом элементе списка содержит полезную информацию, и также содержит служебную информацию. Эта информация, может быть представлена указателем на следующий элемент, точно такой же по структуре. Такой список называется односвязным. Может быть в элементе указатель на предыдущую структуру. Такой список называется двусвязным. Могут быть ещё какие-то указатели на совсем другие структуры, по необходимости. И тогда вообще получается [[ru.wikipedia.org|Дерево]]
  
-При использовании односвязного списка надо быть очень внимательным, чтобы цепочка не разорвалась, т. к. информация за разрывом будет потеряна. При двусвязных списках вероятность такого неприятного события сохраняется, но существенно ниже [3][↑]+При использовании односвязного списка надо быть очень внимательным, чтобы цепочка не разорвалась, т. к. информация за разрывом будет потеряна. При двусвязных списках вероятность такого неприятного события сохраняется, но существенно ниже ((Следует помнить о том, что связанный список для хранения информации может иметь КПД всего 11%: 4 байта на указатель на следующий элемент, 4 байта на предыдущий элемент, и только 1 байт на переменную типа BYTEСоотношение полезной информации к общей как 1 к 9, что и даёт всего 11%. Если уж вы работаете с такой структурой -- стремитесь к тому, чтобы звенья цепи были на два порядка объёмней служебной части такого звена. Например, при служебной информации в 8 байт -- размер полезной информации в звене должен быть около 80-800 байт.))
  
  
Строка 14: Строка 14:
  
 === 2.1 Создание элемента двусвязного списка === === 2.1 Создание элемента двусвязного списка ===
-Для начала создадим тип данных, соответствующей нашей задаче — элемент двусвязного списка. Примерный код представлен ниже:+Для начала создадим тип данных, соответствующей нашей задаче — элемент двусвязного списка. Примерный код представлен ниже: FIXME 
 +<code=oberon2> 
 +</code>
      
 В записи использованы поля для полезного значения, флагов первого и последнего элемента, а также указатели на предыдущий и последний элемент. В записи использованы поля для полезного значения, флагов первого и последнего элемента, а также указатели на предыдущий и последний элемент.
Строка 23: Строка 25:
 Этот тип данных не будет напрямую содержать элементы. В нём будет содержаться только служебная информация по списку, а также указатели на первый и последний элемент списка. Этот тип данных не будет напрямую содержать элементы. В нём будет содержаться только служебная информация по списку, а также указатели на первый и последний элемент списка.
  
-Пример такого списка:+Пример такого списка: FIXME 
 +<code=oberon2> 
 +</code>
  
      
Строка 52: Строка 56:
 === 2.6 Заполнение списка === === 2.6 Заполнение списка ===
   
-Метод будет реализован с помощью цикла FOR. Необходим только для первоначального заполнения списка.+Метод будет реализован с помощью цикла FOR. Необходим только для первоначального заполнения списка. FIXME 
 +<code=oberon2> 
 +</code>
  
      
Строка 63: Строка 69:
  
  
-Внутри метода первый цикл можно заменить на REPEAT...UNTIL. А вот со вторым использовать не получится, так как последний элемент имеющий признак "el.last" не будет выведен на экран. [↑]+Внутри метода первый цикл можно заменить на ''REPEAT...UNTIL''. А вот со вторым использовать не получится, так как последний элемент имеющий признак "el.last" не будет выведен на экран. [↑]
  
  
Строка 76: Строка 82:
 Текст модуля достаточно разобран выше, текст приводится без комментариев. Рекомендуется самостоятельно разобраться в деталях реализации. Текст модуля достаточно разобран выше, текст приводится без комментариев. Рекомендуется самостоятельно разобраться в деталях реализации.
  
-Hello14.odc+Hello14.odc FIXME 
 +<code=oberon2> 
 +</code>
  
        
Строка 84: Строка 92:
  
 === 2.10 Вывод программы === === 2.10 Вывод программы ===
-Если программа набрана правильно, то должен быть получен следующий вывод: +Если программа набрана правильно, то должен быть получен следующий вывод: FIXME 
 +<code> 
 +</code>
      
  [↑]  [↑]
Строка 94: Строка 103:
  
 ==== 4. Примечания ==== ==== 4. Примечания ====
-[↑] Связный список не единственная структура в подобном роде. Варианты списков можно посмотреть в Википедии. Если ей верить, то допустимо использование названий структуры как "Связный список", так и "Связанный список" (от слов "связной" и "связанный"). 
- 
-[↑] Блок-схема — это одна из технологий разработки программного обеспечения (ПО), которая была принята в качестве стандарта на заре компьютерной эпохи. Необходимость в блок-схемах естественно вытекала из-за невыразительности языков программирования. Очень часто в государственных организациях до наших дней можно встретить алгоритмы действий в виде блок-схем на стенах. Блок-схемы несколько архаичны, но например, такой визуальный графический язык, как ДРАКОН ещё не сказал своего слова. Создатели космического корабля "Буран" это подтверждают (см. Википедию). 
- 
-[↑] Следует помнить о том, что связанный список для хранения информации может иметь КПД всего 11%: 4 байта на указатель на следующий элемент, 4 байта на предыдущий элемент, и только 1 байт на переменную типа BYTE. Соотношение полезной информации к общей как 1 к 9, что и даёт всего 11%. 
- 
 [↑] По указателям действие присвоения NIL излишне, в соответствии с документацией, встроенной в КП: "Любой указатель может принимать значение NIL, которое не указывает ни на какую переменную вообще. Все поля и элементы вновь размещенной записи или массива очищаются; в частности, значения все содержащиеся в них указательные и процедурные переменные устанавливаются в NIL." Но мы будем приучаться к методически правильному промышленному программированию. В разных реализациях КП вполне могут встретиться отклонения от эталонного КП. С представленным подходом, в случае необходимости сменить компилятор проблем точно не возникнет, побочные эффекты себя не проявят. [↑] По указателям действие присвоения NIL излишне, в соответствии с документацией, встроенной в КП: "Любой указатель может принимать значение NIL, которое не указывает ни на какую переменную вообще. Все поля и элементы вновь размещенной записи или массива очищаются; в частности, значения все содержащиеся в них указательные и процедурные переменные устанавливаются в NIL." Но мы будем приучаться к методически правильному промышленному программированию. В разных реализациях КП вполне могут встретиться отклонения от эталонного КП. С представленным подходом, в случае необходимости сменить компилятор проблем точно не возникнет, побочные эффекты себя не проявят.
  
bb/redbook/207.1543529584.txt.gz · Последнее изменение: 2020/10/29 07:08 (внешнее изменение)