- •Иркутский государственный университет путей сообщения кафедра “информатика” программирование на языке Cи
- •Иркутск
- •Содержание
- •Предисловие
- •Алфавит языка
- •Служебные слова
- •Константы
- •Комментарии
- •Переменные
- •Int I,j,k; //переменные I, j, k – целого типа
- •Математические функции
- •Математические константы
- •Выражения
- •Выражения целого типа
- •Примеры записи выражений целого типа:
- •Примеры вычислений выражений целого типа:
- •Выражения вещественного типа
- •Примеры записи выражений вещественного типа
- •Примеры вычислений выражений вещественного типа:
- •Операторы присваивания
- •Примеры записи операторов присваивания:
- •Ввод и вывод данных
- •Стандартный ввод-вывод
- •Посимвольный ввод-вывод
- •Ввод-вывод строк
- •Форматированный вывод
- •Форматированный ввод
- •Scanf(“формат”, аргументы);
- •Int age, rost;
- •Vasja Pupkin
- •Vasja Pupkin
- •Структура программы
- •Void main()
- •Int main()
- •Int age, rost;
- •Директивы препроцессора
- •Включение файлов
- •Int main()
- •Int age, rost;
- •Int main()
- •Int age, rost;
- •Подстановка имен
- •Макросы
- •Структуры данных
- •Массивы
- •Int vect[5];
- •Int vect[count];
- •Vect[0] vect[1] vect[2] vect[3] vect[4]
- •Int main()
- •Int temp;
- •Int matr[row][col];
- •Алгоритм и его свойства
- •Схемы алгоритмов
- •Пример записи алгоритма:
- •Базовые структуры
- •Цепочка
- •Ветвления
- •Альтернатива
- •If (условие)
- •Вариант 2 – с использованием операции конъюнкции
- •Int main()
- •Int c, y1, y2, kl, day, month, year;
- •Часто встречающиеся ошибки программирования:
- •Int main()
- •Переключатель
- •Int main()
- •Int month;
- •Часто встречающиеся ошибки программирования:
- •Бесконечные циклы
- •Циклы с предусловием
- •Int main()
- •Программа
- •Int main()
- •Программа
- •Int main()
- •Часто встречающиеся ошибки программирования:
- •Циклы с постусловием
- •Int main()
- •Int main()
- •Программа
- •Int main()
- •Int main()
- •Int main()
- •Int month;
- •Циклы с параметром
- •Действия цикла:
- •Int main()
- •Int top, bottom;
- •Int main()
- •Int num, sum, factor;
- •Int main()
- •Int main()
- •Int main()
- •Int vector_min, vector_max, temp;
- •Int vector[n];
- •Функции
- •Void main()
- •Int summa(int a, int b)
- •Int summa(int a, int b)
- •Void swap(int a, int b)
- •Int temp;
- •Void poplavok(int n, int vector[n])
- •5 * 4 * Factorial(3)
- •5 * 4 * 3 * Factorial(2)
- •5 * 4 * 3 * 2 * Factorial(1)
- •Int fibo(int n)
- •Int binom(int m, int n)
- •Int max_element(int k, int n, int vector[])
- •Int temp;
- •Void quick_sort(int left, int right, int vector[])
- •Адреса и указатели
- •Операции над указателями
- •Указатели и массивы
- •Int mass[5];
- •Int trio[5][2][3];
- •Указатели и функции
- •Int sloshenie(int a, int b);
- •Int sloshenie(int a, int b)
- •Int main()
- •Указатели и строки
- •Функции для работы со строками
- •Vtorokursnik
- •Vtorokursnik
- •Itoa(I, str, 16);
- •Текстовые файлы
- •Int vector[k];
- •Vector_1:
- •Vector_2:
- •Int ocenka;
- •Imja: Vasilij
- •Imja: Ivan
- •Int ocenka;
- •Бинарные файлы
Void main()
{
головная программа с обращениями к функциям
}
описание функций
Таким образом, функции, используемые в программе, должны быть обязательно объявлены – указан их прототип. Прототип – это заголовок функции с указанием ее типа, имени, типов и имен аргументов – формальных параметров:
int summa(int a, int b);
void vorm_mass(int n, int m, int mass[n][m]);
Внимание!После закрывающих скобок точка с запятойставится обязательно!
Таким образом, прототип функции полностью соответствует ее заголовку, используемому при ее дальнейшем описании.
Сами функции описываются после головной программы:
int summa(int a, int b)
{
int s; // s – локальная переменная
s = a + b;
return s; // возврат вычисленного значения
}
void vorm_mass(int n, int m, int mass[n][m])
{
int i, j;
for (i=0; i<n; i++)
for (j=0; j<m; j++)
{
// задание значений элементам массива mass[n][m]
}
}
Внимание!После заголовка функции и закрывающих фигурных скобок точка с запятойне ставится!
В последнем случае оператор returnне нужен, так как функцияvorm_massимеет типvoid– ничего не возвращает.
Если функция не имеет формальных параметров, то их в заголовке функции не указывают, но круглые скобки оставляют.
Необходимо отметить, что описания констант, типов данных и переменных, стоящих внутри фигурных скобок функции, являются локальными, то есть они действуют только в пределах данной функции.
Взаимное расположение функций в программе может быть произвольным. Однако следует избегать обращения к функции, еще не объявленной или не описанной, так как такая функция для компилятора всегда будет иметь тип int.
После заголовка функции записывается телофункции - последовательностьлокальныхописаний и операторов в соответствии с алгоритмом ее работы.
Функция возвращает вычисленное значение, если она заканчивается оператором возврата return, после которого следует имя переменной или выражение, значение которого должна определить функция:
Int summa(int a, int b)
{
return a + b; // возврат вычисленного значения
}
Если после слова returnничего не стоит или этого слова вообще нет в функции, то значит, что данная функция не возвращает никакого значения, и поэтому в ее заголовке должен быть указан типvoid.
Формальные параметры функции в Сисоответствуют параметрам-значениям подпрограмм вПаскале: они служат только для передачи значений фактических параметров в функцию и вычисления ее значения. Поэтому даже если внутри функции они изменяются, то соответствующие им фактические (входные) параметры не изменяются, оставаясь такими же, какими они были при вызове функции:с чем пришел – с тем и ушел:
Int summa(int a, int b)
{
int s; // s – локальная переменная
a++;
b++;
s = a + b;
return s; // возврат вычисленного значения
}
Внутри тела функции формальные параметры aиbувеличились на единицу, и сумма определяется при их новых значениях. При выходе из этой функции фактические (входные) параметры, соответствующие этим формальным параметрам, не изменятся.
Таким образом, функция в Сивычисляетединственноезначение, передаваемое вовне операторомreturn.
При необходимости определить одной функцией значения несколькихпеременных, в списке формальных параметров включаются не имена этих переменных, а их адреса (ссылки), а в теле функции используется операцияразадресации(обращения по адресу)*.
Создадим функцию, которая обменивает значениями две переменных: