Студопедия Главная Случайная страница Обратная связь

Разделы: Автомобили Астрономия Биология География Дом и сад Другие языки Другое Информатика История Культура Литература Логика Математика Медицина Металлургия Механика Образование Охрана труда Педагогика Политика Право Психология Религия Риторика Социология Спорт Строительство Технология Туризм Физика Философия Финансы Химия Черчение Экология Экономика Электроника

Задача 7.1 -а. Передача в функцию имени функции





 

Назовем функцию вывода таблицы значений print_tabl. Прежде всего надо определить ее интерфейс. Для того чтобы вывести таблицу, нашей функции потребуется знать диапазон и шаг изменения значений аргумента, а также какую, собственно, функцию мы собираемся вычислять. Всё? Нет, не все: забыли, что в функцию вычисления суммы ряда надо передавать точность, поэтому точность следует включить в список параметров вызывающей ее функции print_tabl. Функция print_tabl не возвращает никакого значения, то есть перед ее именем надо указать void.

 

Как передать в функцию имя функции? Точно так же, как и любую другую величину: в списке параметров перед именем параметра указать его тип. До этого момента мы передавали в функцию величины стандартных типов, а теперь нам потребуется определить собственный тип. Тип функции определяется типом ее возвращаемого значения и типом ее параметров. Для нашей функции это выглядит так:

 

double (*fun)(double, double);

 

Здесь описывается указатель по имени fun на функцию, получающую два ар мента типа double и возвращающую значение тою же типа (от параметров умолчанию нам, к сожалению, придется отказаться). Часто, если описание типа сложное, целью улучшения читаемости программы задают для него синоним с помощью ключевого слова typedef:

 

typedef double (*Pfun)(double, double);

 

 

В этом операторе задается тип Pfun, который можно использовать наряду со стандартными типами при описании переменных. Таким образом, заголовок функции печати таблицы должен иметь вид:

 

void pr1nt_tabl(Pfun fun. double Xn. double Xk. double dX. double eps):

 

Запишем теперь текст программы, сведя к минимуму диагностику ошибок (при превышении максимально допустимого количества итераций функция завершается, возвращая 0, а вызывающая программа бесстрастно выводит это значение):

 

#include < stdio.h> #include < math.h> typedef double (*Pfun)(const double, const double); void print_tabl(Pfun fun, const double Xn, const double Xk, const double dX, const double eps); double cosh(const double x. const double eps); int main() { double Xn, Xk, dX, eps; printf(" Enter Xn. Xk. dX. eps \n"); scanf(" %lf%lf%lf%lf", & Xn, & Xk, & dX, & eps); print_tabl(cosh, Xn, Xk, dX, eps); return 0; } void print_tabl(Pfun fun, const double Xn, const double Xk, const double dX. const double eps) { printf(" ---------------------------------- \n"); printf(" | X | Y |\n"); printf(" ---------------------------------- \n"); for (double x = Xn; x < = Xk; x += dX) printf(" |%9.2lf |%14.6g |\n", x, fun(x, eps)); printf(" ---------------------------------- \n"); } double cosh(const double x, const double eps) { const int Maxlter = 500; double ch = 1, у = ch; for (int n = 0; fabs(ch) > eps; n++) { ch *= x * x / (2 * n + 1) / (2 * n + 2); y += ch; if (n > MaxIter) return 0; } return у; }

 

Функция print_tabl предназначена для вывода таблицы значений любой функции, принимающей два аргумента типа double возвращающей значение того же типа.

 

Как видите, наряду с большей общностью мы добились и лучшего структурирования программы, разбив ее на две логически не связанные подзадачи: вычисление функции и вывод таблицы. В главной программе остался только ввод исходных данных и вызов функции.

 







Дата добавления: 2014-11-10; просмотров: 759. Нарушение авторских прав; Мы поможем в написании вашей работы!




Практические расчеты на срез и смятие При изучении темы обратите внимание на основные расчетные предпосылки и условности расчета...


Функция спроса населения на данный товар Функция спроса населения на данный товар: Qd=7-Р. Функция предложения: Qs= -5+2Р,где...


Аальтернативная стоимость. Кривая производственных возможностей В экономике Буридании есть 100 ед. труда с производительностью 4 м ткани или 2 кг мяса...


Вычисление основной дактилоскопической формулы Вычислением основной дактоформулы обычно занимается следователь. Для этого все десять пальцев разбиваются на пять пар...

Кран машиниста усл. № 394 – назначение и устройство Кран машиниста условный номер 394 предназначен для управления тормозами поезда...

Приложение Г: Особенности заполнение справки формы ву-45   После выполнения полного опробования тормозов, а так же после сокращенного, если предварительно на станции было произведено полное опробование тормозов состава от стационарной установки с автоматической регистрацией параметров или без...

Измерение следующих дефектов: ползун, выщербина, неравномерный прокат, равномерный прокат, кольцевая выработка, откол обода колеса, тонкий гребень, протёртость средней части оси Величину проката определяют с помощью вертикального движка 2 сухаря 3 шаблона 1 по кругу катания...

Индекс гингивита (PMA) (Schour, Massler, 1948) Для оценки тяжести гингивита (а в последующем и ре­гистрации динамики процесса) используют папиллярно-маргинально-альвеолярный индекс (РМА)...

Методика исследования периферических лимфатических узлов. Исследование периферических лимфатических узлов производится с помощью осмотра и пальпации...

Роль органов чувств в ориентировке слепых Процесс ориентации протекает на основе совместной, интегративной деятельности сохранных анализаторов, каждый из которых при определенных объективных условиях может выступать как ведущий...

Studopedia.info - Студопедия - 2014-2025 год . (0.013 сек.) русская версия | украинская версия