- •Т.Э. Шульга основы программирования на языке с
- •Введение
- •1. Структура программы на языке с
- •Void main()
- •Задание 1. Вывод строки на экран с использованием esp-последовательности
- •2. Переменные. Основные типы данных
- •Задание 2. Описание переменных и преобразование типов
- •3. Ввод – вывод значений переменных
- •Void main()
- •Void main()
- •Задание 3. Форматирование вывода
- •4. Основные операции языка с
- •Void main ()
- •Заданиe 4. Простейшие вычисления
- •5. Конструкции выбора
- •Void main()
- •Void main()
- •Void main()
- •Задание 5. Обработка введенного символа
- •Задание 6. Вычисление значения функции
- •Задание 7. Применение разветвляющихся алгоритмов при решении простейших задач
- •Задание 8. Mультиветвление
- •6. Конструкции цикла и передачи управления
- •Int *t; // неинициализированный указатель на объект типа int,
- •Void main()
- •Int a2[3][2]; // массив из 3 массивов, содержащих по 2 целых элемента.
- •Задание 9. Детерминированные циклы. Простейшие задачи
- •Void main()
- •Задание 10. Итерационные циклы. Простейшие задачи
- •Void main()
- •Int last;
- •Задание 11. Одномерные массивы
- •Void main()
- •Задание 12. Вложенные циклы
- •Void main ()
- •Задание 13. Двумерные массивы
- •Void main ()
- •Задание 14. Посимвольная обработка строк
- •Void main ()
- •Задание 15. Сортировка массива
- •Void main ()
- •7.Функции
- •Int max (int n, int m ) // определение функции нахождения максимума
- •Void main()
- •Int strcmp(const char *str1, const char* str2);
- •Void main()
- •Int fclose (file * stream);
- •Int feof(file *stream);
- •Int fseek ( file* stream, long offset, int origin);
- •Void main ()
- •Задание 16. Определение и вызов функций
- •Задание 17. Рекурсивные функции
- •Задание 18. Использование библиотечных функций string.H
- •Задание 19. Использование библиотечных функций stdio.H
4. Основные операции языка с
Знаки операций в языках программирования обеспечивают формирование и последующие вычисление выражений. Все операции делят на унарные и бинарные. Следует учитывать, что один и тот же символ может обозначать как унарную, так и бинарную операцию в зависимости от контекста. Например, символ “–” может быть унарным или бинарным минусом. Кратко опишем основные операции:
+ |
плюс, унарный и бинарный (+x; x+y); |
| |
– |
минус, унарный и бинарный (–x; x–y); |
| |
++ |
увеличение на единицу (инкремент): (x++ – увеличение значения переменной x после ее использования, ++x – увеличение значения переменной x до ее использования); |
| |
–– |
уменьшение на единицу (декремент): (x–– – уменьшение значения переменной x после ее использования, ––x – уменьшение значения переменной x до ее использования); |
| |
& |
унарная операция получения адреса операнда (&x) ,бинарная поразрядная конъюнкция (И) битовых представлений значений целочисленных операндов, например, 6&5 равно 4, действительно 1102&1012 равно 1002; |
| |
~ |
унарная операция поразрядного инвертирования внутреннего двоичного кода целочисленного аргумента (~x);
|
| |
| |
бинарная поразрядная дизъюнкция (ИЛИ) битовых представлений значений целочисленных операндов, например, 6|5 равно 7, действительно, 1102|1012 равно 1112; |
| |
^ |
бинарная операция поразрядного исключающего ИЛИ (сложение по модулю 2) битовых представлений целочисленных операндов, например, 6^5 равно 3, действительно, 1102|1012 равно 0112; |
| |
<< (>>) |
сдвиг влево (вправо) битового представления значения левого операнда на количество разрядов, равное значению правого операнда, например, 5>>1 равно 2, действительно, 1012 при сдвиге вправо на 1 разряд дает 0102; |
| |
* |
унарная операция обращения по адресу (операция разыменования), бинарная операция умножения; |
| |
/ |
бинарная операция деления; при целочисленных операндах абсолютное значение результата округляется до целого, например, 20/3 равно 6; |
| |
% |
получение остатка от деления целочисленных операндов, например, 20%3 равно 2; |
| |
<(<=) |
меньше (меньше или равно) Результат операций сравнений целочисленный: 0 (ложь) или 1(истина); |
| |
>(>=) |
больше (больше или равно) | ||
== |
равно |
| |
!= |
не равно |
| |
&& |
конъюнкция (И) арифметических операндов или отношений; целочисленный результат: 0 (ложь) или 1(истина); |
| |
|| |
дизъюнкция (ИЛИ) арифметических операндов или отношений; целочисленный результат: 0 (ложь) или 1(истина); |
| |
= |
присвоение (присвоить значение выражения операнда из правой части операнду из левой части: x=20–2*y); |
| |
= |
где – одни из знаков операций *, /, %, +, – ,&,|,^,<<,>>. Операция x=у эквивалентна x=xy, например, x*=2; эквивалентно x=x*2; |
| |
, |
несколько выражений, разделенных запятой вычисляются слева направо, в качестве результата сохраняется тип и значение самого правого выражения, например, d=4,d*2 равно 8; |
|
Кроме того, в языке С определена условная операция, которая используется с тремя операндами и имеет формат:
выражение1 ? выражение2 : выражение3
Если выражение1 истинно, то есть не равно 0, то результатом становится значение выражения2, иначе результатом становится значение выражения3.
Несколько операций языка С, не рассмотренные здесь, будут введены в соответствующих главах.
Теперь, когда введены основные типы данных и операции, можно перейти к решению простейших задач.
Пример. По двум заданным сторонам прямоугольника найти его площадь и длину диагонали.
#include <stdio.h>
#include <math.h>