Pc1 не адресует никакого массива символов

Строка встроенного типа может считаться пустой в двух случаях: если указатель на строку имеет нулевое значение (тогда у нас вообще нет никакой строки) или указывает на массив, состоящий из одного нулевого символа (то есть на строку, не содержащую ни одного значимого символа).

В следующем примере создадим массив указателей на функции.

Полезным приложением указателей на функции является выбор одной из нескольких функций. Ранее рассмотрели использование switch.

 

#include <stdio.h>

#include <iostream>

using namespace std;

void f1(int);

void f2(int);

void f3(int);

int main()

{

setlocale(LC_ALL,".1251");

void (*f_array[])(int)={f1,f2,f3};

int vibor;

do

{

printf("Введите номер функции:1,2,3

или 0 - для финиша\n");

scanf("%d", &vibor);

if (vibor > 0 && vibor < 4)

(*f_array [vibor-1])(vibor);

else

if (vibor == 0) break;

else {

printf("ошибка\n");

vibor = 1;

}

}

while (vibor > 0 && vibor < 4);

printf("финиш\n");

}

void f1(int a)

{printf("Введен номер %d\n", a);}

void f2(int b)

{printf("Введен номер %d\n", b);}

void f3(int c)

{printf("Введен номер %d\n", c);}

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

Пример. Нахождение корня уравнения f(x)=0 на отрезке [a,b] методом деления отрезка пополам с заданной точностью.

 

Напишем рекурсивную функцию для решения этой задачи.

#include <iostream>

#include <cmath>

using namespace std;

double recRoot(double (*f)(double),

double a,double b, double eps)

//double recRoot( double f(double),

// double a, double b, double eps)

{ const double MyNull=1e-12;

double fa=f(a), fb=f(b), c, fc;

if (fa*fb>0)

{ cout << "неверный отрезок\n";

return -999.0;

}

c=(a+b)/2.0;

fc=f(c);

if ((fabs(fc)<=MyNull)||(b-a<=eps))

return c;

return

(fa*fc<=0.0)?recRoot(f,a,c,eps):recRoot(f,c,b,eps);

}

int main()

{ setlocale(LC_ALL,".1251");

double root,

a=0.1, //левая граница отрезка

b=3.5, //правая граница отрезка

eps=1e-5; //точность вычислений

double fun(double);//прототип функции

root=recRoot(fun,a,b,eps);

cout<<"\nкорень="<<root<<"\n";

return 0;

}

double fun(double x) // функция

{ return(2.0/x*cos(x/2.0)); }

Прямая и косвенная рекурсия

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

КОНЕЦ ЛЕКЦИИ

 

char *pc1 = 0;