- •Министерство образования Российской Федерации
- •Свойства алгоритма
- •1.2. Компиляторы и интерпретаторы
- •Языки программирования
- •Состав языка
- •2.2.2. Тип char
- •2.2.3. Тип wchar_t
- •2.2.4. Тип bool
- •2.2.5. Типы с плавающей точкой.
- •2.2.6. Тип void
- •2.3. Переменные
- •2.5. Выражения
- •3. Ввод и вывод данных
- •4.1. Базовые конструкции структурного программирования
- •4.2. Оператор «выражение»
- •4.3. Составные операторы
- •4.4. Операторы выбора
- •4.5. Операторы циклов
- •Операторы перехода
- •5.1. Программирование ветвлений
- •5.2. Программирование арифметических циклов.
- •5.3. Итерационные циклы
- •5.4. Вложенные циклы
- •6. Массивы
- •6.2. Обработка одномерных массивов
- •6.2.1. Перебор массива по одному элементу
- •6.2.2 Формирование псевдодинамических массивов
- •6.2.3. Использование датчика случайных чисел для формирования массива.
- •Найти максимальный элемент массива.
- •6.2.4. Перебор массива по два элемента
- •6.3. Классы задач по обработке массивов
- •6.3.1. Задачи 1-ого класса
- •6.3.2. Задачи 2-ого класса
- •6.3.3. Задачи 3-ого класса
- •6.3.4. Задачи 4-ого класса
- •6.4. Сортировка массивов
- •6.4.1. Сортировка методом простого включения (вставки)
- •6.4.2. Сортировка методом простого выбора
- •6.4.3. Сортировка методом простого обмена
- •6.5. Поиск в отсортированном массиве
- •7. Указатели
- •7.1. Понятии указателя
- •7.2. Динамические переменные
- •7.3. Операции с указателями
- •8.1. Понятие ссылки
- •8.1. Правила работы со ссылками:
- •9. Указатели и массивы
- •9.1. Одномерные массивы и указатели
- •9.2. Многомерные массивы и указатели
- •19.3. Динамические массивы
- •10. Символьная информация и строки
- •11. 1. Объявление и определение функций
- •Прототип функции
- •11.3.Параметры функции
- •11.4. Локальные и глобальные переменные
- •Функции и массивы
- •11.5.1. Передача одномерных массивов как параметров функции
- •11.5.2. Передача строк в качестве параметров функций
- •Передача многомерных массивов в функцию
- •Функции с начальными (умалчиваемыми) значениями параметров
- •13. Подставляемые (inline) функции
- •Перегрузка функций
- •Шаблоны функций
- •17. Указатель на функцию
- •Void f1()
- •19. Типы данных, определяемые пользователем
- •Переименование типов
- •Перечисления
- •Структуры
- •19.3.1. Инициализация структур.
- •19.3.2. Присваивание структур
- •19.3.3. Доступ к элементам структур
- •Указатели на структуры
- •Битовые поля
- •Объединения
- •22. Динамические структуры данных
- •22.1. Линейный однонаправленный список
- •22.2. Работа с двунаправленным списком
- •23. Ввод-вывод в с
- •23.1. Потоковый ввод-вывод
- •23.2. Открытие и закрытие потока
- •23.3. Стандартные файлы и функции для работы с ними
- •23.4. Символьный ввод-вывод
- •23.5. Строковый ввод-вывод
- •23.6. Блоковый ввод-вывод
- •23.7. Форматированный ввод-вывод
- •23.8. Прямой доступ к файлам
- •23.9. Удаление и добавление элементов в файле
- •24. Вопросы к экзамену.
- •25. Примеры задач для подготовки к экзамену
Указатели на структуры
Указатели на структуры определяются также как и указатели на другие типы.
Student*ps;
Можно ввести указатель для типа struct, не имеющего имени (способ 2):
Struct
{
char *name;
int age;
} *person;//указатель на структуру
При определении указатель на структуру может быть сразу же проинициализирован.
Student *ps=&mas[0];
Указатель на структуру обеспечивает доступ к ее элементам 2 способами:
1.(*указатель).имя_элемента
2. указатель->имя_элемента
cin>>(*ps).name;
cin>>ps->title;
Битовые поля
Битовые поля – это особый вид полей структуры. При описании битового поля указывается его длина в битах (целая положительная константа).
Пример:
struct {
int a:10;
int b:14}xx,*pxx;
. . . .
xx.a=1;
pxx=&xx;
pxx->b=8;
Битовые поля могут быть любого целого типа. Они используются для плотной упаковки данных. Например, с их помощью удобно реализовать флажки типа «да» / «нет».
Особенностью битовых полей является то, что нельзя получить их адрес. Размещение битовых полей в памяти зависит от компилятора и аппаратуры.
Объединения
Объединение (union)- это частный случай структуры. Все поля объединения располагаются по одному и тому же адресу. Длина объединения равна наибольшей из длин его полей. В каждый момент времени в такой переменной может храниться только одно значение. Объединения применяют для экономии памяти, если известно, что более одного поля не потребуется. Также объединение обеспечивает доступ к одному участку памяти с помощью переменных разного типа.
Пример
union{
char s[10];
int x;
}u1;
|
|
|
|
|
|
|
|
|
| ||||||
0 |
1 |
2 |
3 |
. . . . |
|
|
|
|
9 | ||||||
x- занимает 2 байта |
|
|
|
|
|
| |||||||||
S – занимает 10 байтов |
Рис.3. Расположение объединения в памяти
И s, и x располагаются на одном участке памяти. Размер такого объединения будет равен 10 байтам.
Пример1:
//использование объединений
enum paytype{CARD,CHECK};//тип оплаты
struct{
paytype ptype;//поле, которое определяет с каким полем объединения будет// выполняться работа
union{
char card[25];
long check;
};
}info;
switch (info.ptype)
{
case CARD:cout<<”\nОплата по карте:”<<info.card;break;
case CHECK:cout<<”\nОплата чеком:”<<info.check;break;
}
22. Динамические структуры данных
Во многих задачах требуется использовать данные, у которых конфигурация, размеры и состав могут меняться в процессе выполнения программы. Для их представления используют динамические информационные структуры. К таким структурам относят:
линейные списки;
стеки;
очереди;
бинарные деревья;
Они отличаются способом связи отдельных элементов и допустимыми операциями. Динамическая структура может занимать несмежные участки динамической памяти.
Наиболее простой динамической структурой является линейный однонаправленный список, элементами которого служат объекты структурного типа (рис.4).
Информационное поле Beg – указатель на начало списка |
адресное поле |
|
|
|
|
|
|
|
Информационное поле |
NULL |
Рис.4. Линейный однонаправленный список