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;