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

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

Задача 8.1. Перегрузка функций





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

 

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

 

#include < fstream.h> #include < string.h> #include < stdlib.h> #include < iomanip.h> const int l_name = 30, l_year = 5. l _pay = 10, l_buf = l_name + l_year + l_pay; steing Man { int brtih_year; char name [l_name + 1]; float pay; }; int read_dbase(const char * filename, Man dbase[], const int l_dbase, int & n_record); void print(Man m); void select(Man dbase [], const int n_record, const int year); void select(Man dbase [], const int n_record, const float pay); int main() { const int l_dbase = 100; Man dbase[l_dbase]; int n_record = 0; if (read_dbase(" txt6.txt", dbase, l_dbase, n_record)! = 0) return 1; int option; int year; float pay; do { cout < < " -----------------------------------" < < endl; cout < < " 1 - Сведения по году рождения" < < endl; cout < < " 2 - Сведения по окладу" < < endl; cout < < " 3 - Выход" < < endl; cin > > option; switch (option) { case 1: cout < < " Введите год "; cin > > year; select(dbase, n_record, year); break; case 2: cout < < " Введите оклад "; cin > > pay; select(dbase, n_record, pay); break; case 3: return 0; default: cout < < " Надо вводить число от 1 до 3" < < endl; } } while (true); return 0; } void select(Man dbase[], const int n_record, const int year) { cout < < " Вывод сведений no году рождения" < < endl; bool success = false; for (int i = 0; i < n_record; i++) if (dbase[i].birth_year > = year) { print (dbase[i]); success = true; } if (! success) cout < < " Таких сотрудников нет" < < endl; } void select(Man dbase[], const int n_record, const float pay) { cout < < " Вывод сведений no окладу" < < endl; bool success = false; for (int i = 0; i < n_record; i++) if (dbase[1].pay > = pay) { print (dbase[i]); success = true; } if(! success) cout < < " Таких сотрудников нет" < < endl; } void print(Man m) { cout.setf(ios:: fixed); cout.precision(2); cout < < setw(40) < < m.name < < ' ' < < m.birth_year < < ' ' < < m.pay < < endl; } int read_dbase (const char * filename. Man dbase[], const int l_dbase, int & n_record) { char buf [l_buf + 1]; ifstream fin(filename, ios:: in | ios:: nocreate); if (! fin) { cout < < " Нет файла " < < filename < < endl; return 1; } int i = 0; while (fin.getline(buf, l_buf)) { strncpy(dbase[i].name, buf, l_name); dbase[i].name[l_name] = '\0'; dbase[i].birth_year = atoi(& buf[l_name]); dbase[i].pay = atof(& buf[l_name + l_year]); i++; if (i > l_dbase) { cout < < " Слишком длинный файл"; return 2; } } n_record = i; fin.close(); return 0; }

 

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

 

Ниже приведены правила описания перегруженных функций.

 

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

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

- Функции не могут быть перегружены, если описание их параметров отличается только модификатором const или использованием ссылки.

 







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




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


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


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


Расчетные и графические задания Равновесный объем - это объем, определяемый равенством спроса и предложения...

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

Йодометрия. Характеристика метода Метод йодометрии основан на ОВ-реакциях, связанных с превращением I2 в ионы I- и обратно...

Броматометрия и бромометрия Броматометрический метод основан на окислении вос­становителей броматом калия в кислой среде...

Хронометражно-табличная методика определения суточного расхода энергии студента Цель: познакомиться с хронометражно-табличным методом опреде­ления суточного расхода энергии...

ОЧАГОВЫЕ ТЕНИ В ЛЕГКОМ Очаговыми легочными инфильтратами проявляют себя различные по этиологии заболевания, в основе которых лежит бронхо-нодулярный процесс, который при рентгенологическом исследовании дает очагового характера тень, размерами не более 1 см в диаметре...

Примеры решения типовых задач. Пример 1.Степень диссоциации уксусной кислоты в 0,1 М растворе равна 1,32∙10-2   Пример 1.Степень диссоциации уксусной кислоты в 0,1 М растворе равна 1,32∙10-2. Найдите константу диссоциации кислоты и значение рК. Решение. Подставим данные задачи в уравнение закона разбавления К = a2См/(1 –a) =...

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