Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
тех прог.doc
Скачиваний:
38
Добавлен:
14.11.2019
Размер:
3.59 Mб
Скачать

Программа 18. Перегрузка функций

// Файл Module.cpp

#include <iostream.h>

#include <conio.h>

// module: возвращает абсолютную величину целого n

int module(int n)

{

if(n < 0)

return -n;

return n;

}

// module: возвращает абсолютную величину плавающего x

double module(double x)

{

if(x < 0)

return -x;

return x;

}

int main()

{

cout << "module(-3.14) = " << module(-3.14f) << "\n";

cout << "module(-3) = " << module(-3) << "\n";

getch();

return 0;

}

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

module(-3.14) = 3.14

module(-3) = 3

Это показывает, что для числа с плавающей точкой -3.14f, имеющего тип float, вызывается функция

double module(double x);

а для целого -3 функция

int module(int n);

7.9.Аргументы функций по умолчанию

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

Программа 19. Аргументы по умолчанию

Функция печати целого print рекурсивная. Если основание системы счисления base <= 10, используются обычные цифры 0, 1, …, 9. Если base > 10, то в качестве цифр используются заглавные латинские буквы A, B, C, D, E, F, G, H,… со значениями: 10, 11, 12, 13, 14, 15, 16, 17,…

// Файл ArgDeflt.cpp

#include <iostream.h>

#include <conio.h>

// print: печать val в системе счисления с основанием base

void print(int val, int base = 10) // 10 – значение для base по умолчанию

{

if(val < 0){

cout.put('-');

print(-val, base);

}

if(val / base > 0) // Если число многозначное,

print(val / base, base); // печатать старшие цифры

int r = val % base; // Остаток от деления

if(r < 10)

cout.put('0' + r);

else

cout.put('A' + r - 10);

}

void main()

{

print(31); cout.put(' '); // По умолчанию base = 10

print(31, 10); cout.put(' ');

print(31, 16); cout.put(' ');

print(31, 2); cout.put('\n');

getch();

}

Программа печатает:

31 31 1F 11111

Для формирования цифр, значения которых больше 9, в функции print использовано выражение:

'A' + r – 10.

Для val = 31 и base = 16 значение остатка r = 31 % 16 = 15. Поэтому

'A' + r – 10 = 'A' + 15 – 10 = 'F'.

Аргументы по умолчанию можно задавать только в конце списка аргументов, например,

int f(int, int = 0, char = 0); // Правильно

int g(int = 0, int = 0, char); // Ошибка

Задачи 70-96. Функции

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

  1. В задаче 14 приведена формула для величины ежемесячных выплат по кредиту. Напишите функцию, возвращающую в качестве результата величину x. Используя эту функцию, напечатайте таблицу значений выплат x в зависимости от количества месяцев N при некоторой фиксированной величине кредита P и процентной ставке r.

  2. Напишите функцию, возвращающую номер первого элемента массива v, совпадающего с x. Если совпадений нет – возвратить -1.

  3. Напишите функцию, возвращающую номер последнего элемента массива v, совпадающего с x, или -1, если совпадений нет.

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

  5. Напишите функцию для нахождения среднего арифметического значения m элементов массива x[] с элементами вещественного типа и функцию для вычисления среднего квадратичного отклонения σ. Формулы следующие:

  1. Напишите функцию, аргументом которой является номер года. Функция должна возвращать 1, если год високосный и 0, если год невисокосный. Год является високосным, если его номер делится на 4 и не делится на 100 или делится на 400. В соответствии с этим правилом 1900-й год был невисокосным, а 2000-й – високосным.

  2. Напишите функцию lower, преобразующую латинские буквы верхнего регистра (заглавные) в латинские буквы нижнего регистра (строчные). Символ, не являющийся буквой, должен возвращаться без изменения. Указание. Используйте тот факт, что как заглавные, так и строчные буквы в кодовой таблице расположены плотно, без разрывов, поэтому разница между кодами одноименных символов одинакова и равна 'a' - 'A'.

  3. Случайные целые числа в диапазоне от -32768 до 32767 можно получить с помощью следующей функции

int casual() // rand: получение псевдослучайных чисел

{ // в диапазоне от -32768 до 32767

static int randx = 1; // Статическая переменная сохраняет свое

// значение между вызовами функции

randx = (randx * 25173 + 13849) % 65536;

return randx;

}

Используя функцию casual(), заполните случайными числами двухмерный массив (квадратную матрицу) размером N * N, где N определите как целую положительную константу. Получите два массива (вектора): вектор, элементы которого равны средним арифметическим значениям строк матрицы, и вектор, элементы которого равны средним арифметическим значениям столбцов матрицы.

  1. Решите предыдущую задачу с использованием библиотечной функции rand, заголовочный файл stdlib.h.

  2. Пусть имеется упорядоченный по возрастанию массив x. Напишите функцию, возвращающую номер элемента массива, имеющего заданное значение y или -1, если такого элемента нет. Используйте метод двоичного (бинарного) поиска: y сравнивается со средним элементом массива; если числа равны, поиск завершается, если y меньше среднего элемента, то y надо искать в левой половине, а иначе – в правой; к выбранной половине применяется тот же алгоритм.

  3. Напишите функцию для вычисления определителя третьего порядка.

  4. Напишите функцию для решения системы линейных уравнений третьего порядка по правилу Крамера.

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

  6. Напишите функцию вычисления определителя четвертого порядка используя разложение определителя по элементам некоторого столбца.

  7. Напишите функцию для решения системы линейных уравнений четвертого порядка по правилу Крамера.

  8. Пусть даны матрица a порядка n и n-мерный вектор b. Напишите функцию, заменяющую заданный столбец матрицы a на вектор b.

  9. Напишите функцию для вычисления обратной матрицы третьего порядка.

  10. Напишите функцию, осуществляющую умножение двух квадратных матриц.

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

  12. Напишите функцию, приводящую квадратную матрицу к треугольному виду методом Гаусса. Функция должна возвращать true при успешном выполнении приведения и false, если в процессе приведения встретилось деление на нуль.

  13. Напишите рекурсивную функцию вычисления факториала n!.

  14. Напишите рекурсивную функцию вычисления числа Фибоначчи с заданным номером. Числа Фибоначчи определяются формулами:

f0 = f1 = 1; fn =fn-1 + fn-2 при n = 2, 3,…

  1. Напишите рекурсивную функцию вычисления целой степени целого числа.

  2. Напишите рекурсивную функцию вычисления целой степени вещественного числа.

  3. Напишите рекурсивную функцию нахождения наибольшего общего делителя NOD(m, n) двух целых m, n по алгоритму Эвклида:

пусть m > n, тогда, если n = 0 то NOD(m, n) = m,

если же n > 0, то NOD(m, n) = NOD(m, – n).

Кроме того, NOD(m, n) = NOD(n, m).

  1. Напишите рекурсивную функцию для нахождения биномиальных коэффициентов, пользуясь их определением:

если m = 0, n > 0 или m = n 0;

если m > n 0;

в остальных случаях.

  1. Напишите рекурсивную функцию вычисления длины строки.