Книга: Борисенко В. В. «Основы программирования»
Серия: "Основы информатики и математики" Книга предназначена для обучения основам программирования. Рассматриваются основные понятия программирования - алгоритма, исполнителя, алгоритмического языка, переменной, основные типы данных, управляющие конструкции алгоритмического языка и т. п. Излагаются общие приемы программирования, основанные на применении математики, такие, как вычисление функций на последовательностях с помощью применения теории индуктивных функций и схема построения цикла с помощью инварианта. Содержание:Глава 1. Общее понятие алгоритма...... 1 1. 1. Алгоритмические языки...... 2 1. 2. Управляющие конструкции алгоритмического языка...... 5 1. 3. Понятие переменной...... 10 1. 4. Типы переменных...... 14 1. 4. 1. Целочисленные переменные...... 14 1. 4. 2. Вещественные переменные...... 20 1. 4. 3. Символьные переменные...... 27 1. 4. 4. Логические переменные и выражения...... 29 1. 4. 5. Массивы...... 32 1. 4. 6. Текстовые строки...... 33 1. 5. Примеры алгоритмов...... 34 1. 5. 1. Вычисление функций на последовательностях...... 34 1. 5. 2. Построение цикла с помощью инварианта...... 51 Глава 2. Устройство компьютера...... 67 2. 1. Оперативная память...... 68 2. 2. Процессор...... 70 2. 2. 1. CISC и RISC-процессоры...... 73 2. 2. 2. Алгоритм работы компьютера...... 74 2. 3. Аппаратный стек...... 75 2. 3. 1. Команды вызова подпрограммы call и возврата return...... 77 2. 3. 2. Аппаратный стек и локальные переменные подпрограммы...... 78 2. 4. RTL: машинно-независимый Ассемблер...... 81 2. 4. 1. Примеры программ на RTL и Ассемблере Intel 80x86...... 84 2. 4. 2. Задачи по теме «Программирование на Ассемблере»...... 90 2. 5. Внешние устройства и аппаратные прерывания...... 91 2. 6. Виртуальная память и поддержка параллельных задач...... 93 2. 6. 1. Страничная организация памяти...... 93 2. 6. 2. Переключение между процессами и нитями...... 94 Глава 3. Основы языка Си...... 97 3. 1. Структура Си-программы...... 98 3. 2. Функции...... 101 3. 2. 1. Программа "Hello, World!"...... 102 3. 3. Типы переменных...... 104 3. 3. 1. Базовые типы...... 104 3. 3. 2. Конструирование новых типов...... 109 3. 4. Выражения...... 119 3. 4. 1. Оператор присваивания...... 119 3. 4. 2. Арифметические операции...... 120 3. 4. 3. Операции увеличения и уменьшения...... 121 3. 4. 4. Операции «увеличить на», «домножить на» и т. п...... 123 3. 4. 5. Логические операции...... 125 3. 4. 6. Операции сравнения...... 126 3. 4. 7. Побитовые логические операции...... 127 3. 4. 8. Операции сдвига...... 131 3. 4. 9. Арифметика указателей...... 132 3. 4. 10. Связь между указателями и массивами...... 134 3. 4. 11. Операция приведения типа...... 135 3. 5. Управляющие конструкции...... 137 3. 5. 1. Фигурные скобки...... 138 3. 5. 2. Оператор if...... 138 3. 5. 3. Выбор из нескольких возможностей: if...else if...... 140 3. 5. 4. Пример: решение квадратного уравнения...... 141 3. 5. 5. Цикл while...... 145 3. 5. 6. Пример: вычисление квадратного корня методом деления отрезка пополам...... 147 3. 5. 7. Выход из цикла break, переход на конец цикла continue...... 149 3. 5. 8. Оператор перехода на метку goto...... 151 3. 5. 9. Цикл for...... 152 3. 5. 10. Операция «запятая» и цикл for...... 154 3. 5. 11. Конструкции, которые лучше не использовать...... 156 3. 6. Представление программы в виде функций...... 160 3. 6. 1. Прототипы функций...... 160 3. 6. 2. Пример: вычисление наибольшего общего делителя...... 161 3. 6. 3. Передача параметров функциям...... 162 3. 6. 4. Пример: расширенный алгоритм Евклида...... 163 3. 7. Работа с памятью...... 166 3. 7. 1. Статическая память...... 166 3. 7. 2. Стековая, или локальная, память...... 169 3. 7. 3. Динамическая память, или куча...... 170 3. 7. 4. Пример: печать п первых простых чисел...... 172 3. 7. 5. Операторы new и delete языка С++...... 174 3. 8. Структуры...... 177 3. 8. 1. Структуры и указатели...... 179 3. 8. 2. Пример: рекурсивный обход дерева...... 181 3. 8. 3. Структуры и оператор определения типа typedef...... 183 3. 9. Технология программирования на Си...... 185 3. 9. 1. Представление матриц и многомерных массивов...... 185 3. 9. 2. Пример: приведение матрицы к ступенчатому виду методом Гаусса...... 188 3. 9. 3. Работа с файлами...... 196 3. 9. 4. Работа с текстами...... 219 3. 9. 5. Разработка больших проектов...... 240 3. 9. 6. Задачи по теме «Технология программирования на Си»...... 242 Глава 4. Структуры данных...... 246 4. 1. Общее понятие структуры данных...... 246 4. 2. Массив как базовая структура...... 248 4. 3. Реализация одних структур на базе других...... 249 4. 4. Простейшие структуры данных. Стек. Очередь...... 250 4. 4. 1. Очередь...... 250 4. 4. 2. Стек...... 253 4. 5. Ссылочные реализации структур данных...... 283 4. 5. 1. Массовые операции...... 284 4. 5. 2. Список...... 285 4. 5. 3. Ссылочная реализация списка...... 286 4. 5. 4. Деревья и графы...... 287 4. 6. Множество...... 291 4. 6. 1. Реализации множества: последовательный и бинарный поиск, хеширование...... 293 4. 6. 2. Бинарный поиск...... 294 4. 6. 3. Реализации множества на базе деревьев...... 297 4. 6. 4. Хеширование...... 304 4. 6. 5. Циклы «для каждого» и итераторы...... 306 4. 7. Задачи по теме «Структуры данных»...... 307 Литература...... 309 Предметный указатель...... 311 Издательство: "Интернет-Университет Информационных Технологий" (2005)
ISBN: 5955600396 |
Другие книги схожей тематики:
Автор | Книга | Описание | Год | Цена | Тип книги |
---|---|---|---|---|---|
А. Л. Марченко | Основы программирования на С# 2. 0 | Книга представляет собой пособие по изучению языка программирования С#, который является одним из важных… — Интернет-университет информационных технологий, Бином. Лаборатория знаний, (формат: 60x90/16, 552 стр.) Основы информационных технологий Подробнее... | 2007 | 483 | бумажная книга |
Марина Барышникова | Основы программирования на С_С++ | Учебное пособие представляет собой краткое изложение лекционного курса «Программирование на языке С»… — МГТУ им. Н.Э. Баумана, электронная книга Подробнее... | 2007 | 118 | электронная книга |
В. М. Бондарев, В. И. Рублинецкий, Е. Г. Качко | Основы программирования | В компактной форме изложен мастерски написанный курс обучения основам программирования. Первая часть книги… — Фолио, Феникс, (формат: 84x108/32, 368 стр.) Подробнее... | 1997 | 220 | бумажная книга |
Валентина Хиценко | Основы программирования | В настоящем учебном пособие излагаются основные понятия и приемы программирования на стандартном языке Си… — Новосибирский государственный технический университет, электронная книга Подробнее... | 2015 | 75 | электронная книга |
С. М. Окулов | Основы программирования | В книге рассмотрены фундаментальные положения программирования: конечная величина и конструируемые на ее… — Лаборатория знаний, Развитие интеллекта школьников электронная книга Подробнее... | 2012 | 264 | электронная книга |
С. М. Окулов | Основы программирования | В книге рассмотрены фундаментальные положения программирования: конечная величина и конструируемые на ее… — Бином. Лаборатория знаний, (формат: 60x90/16, 336 стр.) Развитие интеллекта школьников Подробнее... | 2015 | 322 | бумажная книга |
Окулов Станислав Михайлович | Основы программирования | В книге рассмотрены фундаментальные положения программирования: конечная величина и конструируемые на ее… — Бином. Лаборатория знаний, Развитие интеллекта школьников Подробнее... | 2018 | 669 | бумажная книга |
Окулов Станислав Михайлович | Основы программирования | В книге рассмотрены фундаментальные положения программирования: конечная величина и конструируемые на ее… — Бином. Лаборатория знаний, (формат: 150x220, 336 стр.) Развитие интеллекта школьников Подробнее... | 2018 | 525 | бумажная книга |
Галина Иванова | Основы программирования | — МГТУ им. Н.Э. Баумана, электронная книга Подробнее... | 472 | электронная книга | |
С. Окулов | Основы программирования | Книга известного специалиста по программированию посвящена формированию главных качеств профессиональных… — Бином. Лаборатория знаний, (формат: 60x90/16, 440 стр.) Подробнее... | 2010 | 735 | бумажная книга |
См. также в других словарях:
ОСНОВЫ ИНФОРМАТИКИ И ВЫЧИСЛИТЕЛЬНОЙ ТЕХНИКИ — (ОИВТ), уч предмет, введенный в ср у ч заведения Рос Федерации с 1985/86 у ч г. Предусматривает изучение законов и методов сбора, передачи и обработки информации с помощью электронной вычислит техники Цель обучения ОИВТ формирование «компьютерной … Российская педагогическая энциклопедия
Go (язык программирования) — О языке программирования, появившемся в 2003 году, см.: Go! (язык программирования) Go Класс языка: компилируемый, многопоточный, императивный, структурированный Появился в: 2009 г … Википедия
AWL (язык программирования) — AWL (Alternative Web Language) Класс языка: мультипарадигмальный: функциональный, процедурный, объектно ориентированный Тип исполнения: интерпретируемый Появился в: 2005 г. Типизация данных: динамическая … Википедия
Парадигма программирования — Парадигмы программирования Агентно ориентированная Компонентно ориентированная Конкатенативная Декларативная (контрастирует с Императивной) Ограничениями Функциональная Потоком данных Таблично ориентированная (электронные таблицы) Реактивная … Википедия
Паскаль (язык программирования) — Эта статья или раздел нуждается в переработке. В Паскале нет модулей, ООП и прочих новомодных веяний. Описание расширений должно присутствовать только в статьях о соответ … Википедия
Forth (язык программирования) — Forth Семантика: императивный Тип исполнения: интерпретатор/компилятор Появился в: 1971 г. Автор(ы): Чарльз Х. Мур Основные реализации: gForth, pForth, kForth, SP Forth, win32forth … Википедия