- •4. 1. Базовые средства языка
- •Алфавит языка
- •4.1.5. Типы данных Си
- •Логический тип
- •4.1.8. Операции и выражения
- •Операции присваивания
- •Арифметические операции
- •Логические операции
- •4.1.10. Структура программы
- •4.1.11. Ввод и вывод данных
- •Функции ввода- вывода
- •Объектно-ориентированные средства ввода-вывода.
- •4.2. Операторы управления
- •4.2.1. Понятие алгоритма
- •4.2.2. Изображение алгоритма в виде блок-схемы
- •2.3. Составной оператор
- •2.4. Операторы ветвления
- •If (выражение) оператор;
- •4.2.5. Примеры программ
- •4.2.6. Оператор варианта
- •4.2.7. Алгоритмы циклической структуры
- •Оператор цикла с предусловием
- •Оператор цикла с постусловием
- •Оператор цикла с параметром
- •Операторы передачи управления
- •4.2.8. Решение задач с использованием циклов
- •4.3. Обработка массивов
- •4.3.1. Описание массивов
- •4.3.2. Основные операции над массивами
- •4.3.3. Ввод-вывод элементов массива
- •4.3.4. Вычисление суммы элементов массива
- •4.3.5. Вычисление произведения элементов массива
- •4.3.6. Поиск максимального элемента и его номера
- •4.3.7. Сортировка элементов в массиве
- •4.3.8. Удаление элемента из массива
- •4.3.9. Решение задач с использованием массивов
- •4.4. Обработка матриц
- •4.4.1. Ввод-вывод матрицы
- •4.4.2. Примеры алгоритмов обработки матрицами
- •4.5.1. Передача параметров в функцию
- •4.5.2. Возврат результата с помощью оператора return
- •4.6. Указатели и динамические массивы
- •5. Примеры организации вычислительного процесса
- •5.1 Организация разветвляющегося вычислительного процесса
- •5.2. Организация циклов с известным числом повторений»
- •Блок-схема
- •Текст программы
- •Блок-схема
- •Текст программы
- •5.4.Обработки одномерного массива с перестановкой элементов
- •5.5. Обработка матрицы.
- •Литература
4.5.1. Передача параметров в функцию
Обмен информацией между вызываемой и вызывающей функциями осуществляется с помощью механизма передачи параметров.
Список_переменных, указанный в заголовке функции называется формальными параметрами или просто параметрами функции.
Список_переменных в операторе вызова функции это фактические параметры или аргументы.
Механизм передачи параметров обеспечивает замену формальных параметров фактическими параметрами, и позволяет выполнять функцию с различными данными.
Количество, типы и порядок следования формальных и фактических параметров должны совпадать.
Передача параметров выполняется так:
вычисляются выражения, стоящие на месте фактических параметров;
в памяти выделяется место под формальные параметры, в соответствии с их типами;
формальным параметрам присваиваются значения фактических параметров;
выполняется проверка типов и при необходимости выполняется их преобразование, при несоответствии типов выдается диагностическое сообщение.
Передача параметров в функцию может осуществляться по значению и по адресу.
При передаче данных по значению функция работает с копиями фактических параметров, и доступа к исходным значениям аргументов у нее нет.
При передаче данных по адресу функция обращается к адресам фактических параметров и имеет доступ к ячейкам памяти, в которых хранятся значения аргументов.
Таким образом, данные, переданные по значению, функция изменить не может, в отличие от данных, переданных по адресу.
4.5.2. Возврат результата с помощью оператора return
Возврат результата из функции в вызывающую ее функцию осуществляется оператором
return (выражение);
Работает оператор так:
вычисляется значение выражения, указанного после return и преобразуется к типу возвращаемого функцией значения;
выполнение функции завершается, а вычисленное значение передается в вызывающую функцию;
операторы, следующие в функции за оператором return, игнорируются;
программа продолжает свою работу с оператора следующего за оператором вызова данной функции.
Оператор return может отсутствовать:
в функциях типа void;
если возврат происходит перед закрывающейся фигурной скобкой;
в функции main.
Функция может содержать несколько операторов return.
4.6. Указатели и динамические массивы
Идея работы с указателями состоит в том, что пользователь работает с адресом ячейки памяти и имеет возможность динамически создавать и уничтожать переменные.
5. Примеры организации вычислительного процесса
5.1 Организация разветвляющегося вычислительного процесса
Постановка задачи
1. Исходные данные: a,b,c .
2. Математическая модель:
3.Выводимые данные : x, y
4. Аномалии: а) bc ≠ 0 , если a<bc ; b) ax ≠ 0 , если -2 ≤ x ≤ 2
.
Блок-схема алгоритма
Текст программы
#include <stdio.h>
#include<math.h>
main()
{
int a,b,c;
float x,y;
clrscr();
printf ("Vvedite A,B i C cherez probel:");
scanf("%d%d%d",&a,&b,&c);
if(a>=b*c)
x=sqrt(a-b*c);
else
if(b*c!=0)
{x=(float)a/(b*c); }
else
{printf("\nResheniya net!");
exit(1);
}
printf("\nX=%10.4f",x);
if(x>=-2)
y=x*(a+b+c);
else
if(x>=2)
y=log(x)-b;
else
if(x!=0 && a!=0)
y=(a*a+b*c)/(a*x);
else
{printf("\nResheniya net!");
exit(1);
}
printf("\nY=%10.4f",y);
getch(); }