-
Notifications
You must be signed in to change notification settings - Fork 16
Data Structures and Algorithms
garevna edited this page Nov 3, 2018
·
3 revisions
- Структуры данных - это способы организации и хранения данных
- Алгоритм — последовательность действий ( операций )
Структуры данных и алгоритмы тесно связаны
В зависимости от выбранной структуры данных применяются различные алгоритмы доступа к данным
Алгоритмы характеризуются производительностью
- число операций алгоритма
- объем необходимой памяти
У каждого дерева есть корень ( root ) и узлы ( node )
Двоичное дерево:
- каждый узел имеет не более двух дочерних узлов
- левый дочерний узел имеет значение, меньше чем значение родительского узла
- правый дочерний узел имеет значение, больше или равное значению родительского узла
var Collection = function ( name, createItem ) {
this.items = []
this.name = name || "collection"
this.itemsCounter = ( function () {
var counter = 0
return function ( operationType ) {
return Math.abs ( operationType ) !== 1 ?
counter : counter += operationType
}
})()
this.createItem = typeof createItem === "function" ?
createItem : null
}
Collection.prototype.removeItem = function ( itemNum ) {
if ( itemNum > this.itemsCounter () ) return false
this.items = this.items.filter ( x => {
if ( x.index > itemNum ) --x.index
return x.index !== itemNum
})
}
Collection.prototype.addItem = function ( item ) {
item.index = this.itemsCounter ( 1 )
this.items.push ( this.createItem ? this.createItem ( item ) : item )
}var tags = new Collection ( "elements", function ( params ) {
var elem = document.createElement ( params.tagName || "div" )
var parentElement = params.parent || document.body
parentElement.appendChild ( elem )
if ( params.id ) elem.id = params.id
if ( params.className )
elem.id = params.className
elem.innerHTML = params.innerHTML || ""
if ( params.styles && typeof params.styles === "object" ) {
for ( var x in params.styles ) {
console.log ( x )
elem.style [ x ] = params.styles [x]
}
}
return elem
} )
© Irina H.Fylyppova 2018
Использование данных материалов или любой их части коммерческими школами ( курсами ) является нарушением авторских прав
| 1 | 2 | 3 | 4 | 5 |
| 6 | 7 | 8 | 9 | 10 |
| 11 | 12 | 13 | 14 | 15 |
| 16 | 17 | 18 | 19 |
| ⏬ |
|---|
- Блок-схема алгоритма
- Developer Tools
- Chrome DevTools
- Переменные
- Оператор typeof
- Структуры данных
- Операторы присваивания
- Логические выражения
- Условные операторы
- Инкремент
- Свойство length
- Оператор цикла for
- UTF-8
Homework
- Приведение типов
- NaN | null | Infinity
- BigInt (ES10)
- Функции
- Методы
- Методы строк
- Методы массивов
- Date ()
Самостоятельная работа
Практика (XSS)
Homework
- Циклы while и do...while
- Циклы for...of и for...in
- Параметры по умолчанию
- Объект function
Практика
Homework
- Нативные и host-объекты
- Литерал объекта
- Унаследованные свойства
- Конструктор
- Модель наследования
- Публичные и приватные свойства
- Оператор in
1
Homework
- Итерирующие методы массивов
- Тестирование производительности
- SHA
Homework
- Размеры и прокрутка элемента
- Event Loop
- async | await
- API
- REST | HATEOAS
- status codes
JSON placeholder-
JSON server
fake chat
Homework
- strict mode
- Вычисляемые имена свойств
- Краткий синтаксис методов
- Краткий литерал объекта
- Классы
Homework
- :not(:defined)
- Shadow DOM
- Custom elements
- Lifecycle hooks
- whenDefined
- <template>
- slot
1
2
3
Homework
- npm
- webpack
Упражнение 1- ES6 модули
Упражнение 2- --mode | --watch
Упражнение 3
Упражнение 4
Упражнение 5
Упражнение 6
Упражнение 7
Упражнение 8
Homework
| ⏫ |
|---|

Дополнительно
Справочная инфо
Git Bush
TCP/IP
Коды символов