- •1. История создания языка с.
- •2. Основные характеристики алгоритмического языка Си.
- •3. Область применения и системы программирования языка Си.
- •4. Исходные и объектные модули, процессы компиляции и связывания.
- •5. Алфавит языка Си. Лексемы
- •6. Ключевые слова языка Си.
- •7. Знаки пунктуации, специальные символы и знаки операций в языке Си.
- •8. Идентификаторы в языке Си.
- •9. Виды констант в языке Си.
- •10. Константы целые и вещественные.
- •11. Символьные константы.
- •12. Строковые константы.
- •13. Типы данных: целый, вещественный, символьный.
- •14. Представление данных в оперативной памяти. Размеры данных.
- •15. Правила определения переменных в программе. Инициализация переменных.
- •16. Определение именованных констант. Спецификация типов.
- •17. Выражения: математические, логические, текстовые.
- •18. Унарные операции.
- •19. Классификация бинарных операций.
- •20. Арифметические и поразрядные операции.
- •21. Операции сдвига.
- •22. Операции отношения, логические операции.
- •23. Операции присваивания.
- •24. Условная трехместная операция.
- •25. Преобразование типов.
- •26. Приоритет операций и порядок вычисления выражений.
- •27. Функция форматированного вывода printf.
- •28. Функция форматированного ввода информации scanf.
- •29. Понятие оператора. Оператор простой и составной, блок.
- •30. Виды управляющих конструкций программы.
- •31. Операторы ветвления, условный оператор.
- •32. Метки и переходы. Пустой оператор. Оператор выбора (переключатель).
- •33. Структурные схемы циклических процессов.
- •34. Операторы цикла: цикл с заданным числом повторений.
- •35. Операторы цикла: цикл с предусловием.
- •36. Операторы цикла. Цикл с постусловием.
- •37. Операторы прерывания и продолжения цикла. Вложенные циклы.
- •38. Одномерные и многомерные массивы, их инициализация.
- •39. Указатели. Связь между указателями и массивами.
- •40. Операции над указателями.
- •41. Массивы переменных размеров. Функции использования динамической памяти.
- •42. Определение функций. Программирование с использованием функций. Возвращение значения: оператор return.
- •43. Аргументы функции: формальные и фактические. Передача аргументов, стек.
- •44. Указатели на функции. Массивы указателей на функции. Указатель на функцию в качестве аргумента другой функции.
- •45. Рекурсивные программы.
- •46. Функции для работы со строками: сравнение, копирование.
- •47. Функции для работы со строками: поиск в строке.
- •48. Функции для работы со строками: преобразование форматов.
- •49. Декларация структур.
- •50. Инициализация и доступ к элементам структуры.
- •51. Вложенные структуры и массивы структур.
- •52. Указатели на структуры.
- •53. Использование структур в качестве аргументов функций.
- •54. Объединения и битовые поля.
- •55. Локальные и глобальные переменные.
- •56. Классы памяти.
- •57. Автоматические и регистровые переменные.
- •58. Внешние и статические переменные, особенности их реализации.
- •59. Символические константы: #define. Включение файла: #include.
- •60. Директивы препроцессора: #if, #ifdef, #ifndef, #else, #endif.
- •61. Файлы. Двоичное и текстовое представление файлов.
- •62. Стандартные файлы (потоки).
- •63. Понятие потока.
- •64. Открытие и закрытие файлов.
- •65. Операции файлового ввода-вывода.
- •66. Позиционирование. Указатель чтения –записи в файле.
- •67. Организация низкоуровневого ввода-вывода.
- •68. Функции обслуживания файлов низкоуровневого ввода-вывода.
34. Операторы цикла: цикл с заданным числом повторений.
Операторы цикла служат для многократного выполнения последовательности операторов до тех пор, пока выполняется некоторое условие.
Общая форма оператора for следующая:
for(инициализация; условие; приращение) оператор;
Инициализация – это присваивание начального значения переменной, которая называется параметром цикла. Условие представляет собой условное выражение, определяющее, следует ли выполнять оператор цикла в очередной раз. Оператор приращение осуществляет изменение параметра цикла при каждой итерации. Эти три оператора (они называются также секциями оператора for) обязательно разделяются точкой с запятой. Цикл for выполняется, если выражение условие принимает значение истина. Если оно хотя бы один раз примет значение ложь, то программа выходит из цикла и выполняется оператор, следующий за телом цикла for.
В следующем примере в цикле for выводятся на экран числа от 1 до 100:
#include <stdio.h>
int main(void)
{
int x;
for(x=1; x<=100; x++) printf(“%d”,x);
return0;
}
В этом примере параметр цикла x инициализирован числом 1, а затем при каждой итерации сравнивается с числом 100. Пока переменная х меньше 100, вызывается функция printf() и цикл повторяется. При этом х увеличивается на 1 и опять проверяется условие цикла x<=100. Процесс повторяется, пока переменная х не станет больше 100. После этого процесс выходит из цикла, а управление передается оператору, следующему за ним. В этом примере параметром цикла является переменная х, при каждой итерации она изменяется и проверяется в секции условия цикла.
В операторе for условие цикла всегда проверяется перед началом итерации. Это значит, что операторы цикла могут не выполняться ни разу, если перед первой итерацией условие примет значение ложь.
35. Операторы цикла: цикл с предусловием.
Общая форма цикла while имеет следующий вид:
while(условие) оператор;
Здесь оператор (тело цикла) может быть пустым оператором, единственным оператором или блоком. Условие (управляющее выражение) может быть любым допустимым в языке выражением. Условие считается истинным, если значение выражения не равно нулю, а оператор выполняется, если условие принимает значение истина. Если условие принимает значение ложь, программа выходит из цикла и выполняется следующий за циклом оператор.
В следующем примере ввод с клавиатуры происходит до тех пор, пока пользователь не введет символ А:
char wait_for_char(void)
{
char ch;
ch=’\0’;
while (ch!=’A’) ch=getchar();
return ch;
}
Переменная сh является локальной, ее значение при входе в функцию произвольно, поэтому сначала значение ch инициализируется нулем. Условие цикла while истинно, если ch не равно А. Поскольку ch инициализировано нулем, условие истинно и цикл начинает выполняться. Условие проверяется при каждом нажатии клавиши пользователем. При вводе символа А условие становится ложным и выполнение цикла прекращается.
В цикле while условие проверяется перед началом итерации. Это значит, что если условие ложно, тело цикла не будет выполнено.