И.А. Волкова, А.А. Вылиток, Л.Е. Карпов - Сборник задач и упражнений по языку Си++, страница 5
Описание файла
PDF-файл из архива "И.А. Волкова, А.А. Вылиток, Л.Е. Карпов - Сборник задач и упражнений по языку Си++", который расположен в категории "". Всё это находится в предмете "практика расчётов на пэвм" из 3 семестр, которые можно найти в файловом архиве МГУ им. Ломоносова. Не смотря на прямую связь этого архива с МГУ им. Ломоносова, его также можно найти и в других разделах. .
Просмотр PDF-файла онлайн
Текст 5 страницы из PDF
Добавить в функцию f9 () использование механизма приведения типов так, чтобыее выполнение всегда завершалось нормально.struct Bstruct D:void f9 (BD * pdstrcpy}{ virtual void g () {} };B { char y [100]; };& b, D & d, int n) {= (n > 0) ? & d : (D *) & b;(pd -> y, “one_variant\n”);7.3. Добавить в функцию putnull () использование механизма приведения типов так,чтобы ее выполнение всегда завершалось нормально.struct B{ virtual void empty () {} };struct D: B { int mas [30]; };void putnull (B * pb){D * pd = (D *) pb;if (! pb) return;for (int i = 0; i < 30; i++) pd -> mas [i] = 0;}7.4. Добавить в функцию puthi () использование механизма приведения типов, так,чтобы ее выполнение всегда завершалось нормально.struct B{ virtual void hi () { cout << “Hi!” << endl; } };struct D: B { char txt [10] [4]; };void puthi (B * pb, D * pd) {int i = 10;if (! pb) return;pd = (D *) pb;while (i) strcpy ((pd -> txt) [--i], ”Hi!”);}457.5.
Какие виды операций преобразования типов имеются в языке Си++? Укажитеназначение каждого вида, приведите пример записи каждой из перечисленныхопераций.7.6. Для приведённой ниже программы описать функцию f (), которая, получая в качестве параметра указатель типа A*, возвращает его значение, наиболее безопаснымобразом преобразованное к типу B*, а в случае невозможности преобразованиякорректно завершает работу программы.struct A{ virtual void z () {} };struct B: A { int x; B (int y = 5) { x = y; } };B * f (A * pa);int main (){try {B b, * pb = f (& b);cout << pb -> x << endl;A a;pb = f (& a);cout << pb -> x << endl;}catch (...) { }return 0;}7.7.
Для приведённой ниже программы описать функцию f (), которая, получая в качестве параметра ссылку на объект базового класса A, возвращает ссылку на объектпроизводного класса C, полученную наиболее безопасным образом, а в случае невозможности приведения типов корректно завершает программу.struct A{ virtual void z () {} };struct B: A { };struct C: B { int x; C (int n = 3) { x = n; } };C & f (A & ra);int main () {C c, & pc = f (& c);cout << pc.x << endl;return 0;}7.8. Для приведённой ниже программы описать функцию f (), которая, получая в качестве параметра ссылку на объект типа void *, возвращает ссылку на объект производного класса B, полученную наиболее безопасным образом, а в случае невозможности приведения типов корректно завершает программу.struct A{ virtual void z () {} };struct B: A { int x; B (int n = 7) { x = n; } };B * f (void * p);int main () {B b, * pb = f (& b);cout << pb -> x << endl;return 0;}467.9.
Для приведённой ниже программы описать функцию f (), которая, получая в качестве параметра ссылку на объект класса B, возвращает указатель на объект классаC, полученный наиболее безопасным образом, а в случае невозможности приведения типов корректно завершает программу.struct A{struct B: A{struct C: B{C * f (B & rb);int main () {C c, * pc = fcout << pc ->return 0;}int x; virtual void z () {} };int x; };int x; C (int n = 4) { x = n; } };(c);x << endl;7.10. Можно ли получить информацию о типе объекта во время работы программы наСи++?Какие операции языка Си++ используются в подобных случаях?Для объектов каких типов эти операции имеют смысл?Какие стандартные исключения генерируются в результате выполнения этих операций?Привести пример программы, в которой используются эти операции.8.Шаблоны8.1. Привести пример использования параметрического полиморфизма в Си++.8.2.
Есть ли ошибки в следующих заголовках шаблонов?Если есть, поясните, в чём они заключаются.template <double f> void funcA (double d = f) { /*...*/ }template <float f> class A { /*...*/ };template <int n> class B { /*...*/ };template <int n> void funcB (int t = n) { /*...*/ }template <class Cs> class C { /*...*/ };template <class Cs> struct D { /*...*/ };template <class Cs> void funcC (const Cs& ref) { /*...*/ }class myclass { public: myclass() {} };template <myclass c> class E { /*...*/ };struct mystruct { int a, b; };template <class mystruct> void funcD (mystruct *p = 0) { /*...*/ }template <mystruct a> void funcE (mystruct *p = &a) { /*...*/ }template <struct mystruct> void funcF (mystruct *p = 0) { /*...*/ }8.3. Есть ли ошибки в приведенном фрагменте программы на Си++? Если есть, тообъясните, в чем они заключаются.
Ошибочные конструкции вычеркните из текста программы. Что будет напечатано при вызове функции main ()?47class complex {double re, im;public:complex (double r = 0, double i = 0) {re = r;im = i;cout << “constr” << endl;}operator double () {cout << “operator double ” << endl;return re;}double get_re () { return re; }void print() const {cout << "re=" << re << " im=" << im << endl;}};template <class T>T f (T& x, T& y) {cout << "template f" << endl;return x > y ? x : y;}double f (double x, double y){cout << "ordinary f" << endl;return x > y ? –x : –y;}int main (){complex a(2, 5), b(2, 7), c;double x = 3.5, y = 1.1;int i, j = 8, k = 10;c = f (a, b);cout << "c = ";c.print ();x = f (a, y);cout << "x = " << x <<endl;i = f (j, k);cout << "i = " << i <<endl;cout << "Выбор сделан!" << endl;return 0;}8.4.
Есть ли ошибки в приведенном фрагменте программы? Если есть, то объясните, вчем они заключаются. Ошибочные конструкции вычеркните из текста программы.Что будет напечатано при вызове функции main ()? Перегрузите шаблоннуюфункцию max () так, чтобы сравнение строк осуществлялось лексикографически(то есть в соответствии с кодировкой символов).template <class T>T max (T& x, T& y) {return x > y ? x : y;}48int main () {double x = 1.5, y = 2.8, z;int i = 5, j = 12, k;char * s1 = "abft";char * s2 = "abxde", * s3;z = max (x, y);cout << "z = "<< z << endl;k = max <int>(i, j);cout << "k = "<< k << endl;z = max (x, (double &) i);cout << "z = "<< z << endl;z = max (y, (double &) j);cout << "z = "<< z << endl;s3 = max (s1, s2);cout << "s3 = "<< s3 << endl;cout << "Выбор сделан!" << endl;}return 0;8.5.
Какие из следующих утверждений являются верными, а какие — ошибочными?Объясните, в чем заключаются эти ошибки.в одной зоне описания не может быть описано несколько шаблонов класса содинаковыми именамишаблонная функция и обычная функция в одной зоне описания не могут иметьодинаковые имена8.6. Для класса рациональных дробей с числителями и знаменателями некоторого интегрального типаtemplate<class T> class fr { T n; T d; ... };описать два варианта (методом класса и функцией-другом этого класса) реализации вне класса операций, либо объяснить, почему какой-либо из вариантов невозможен:'+', выполняющей сокращение числителя и знаменателя рациональной дроби,если они имеют общие множители (унарный «+»).'+', выполняющей сложение двух рациональных дробей, либо рациональнойдроби и значения соответствующего интегрального типа.'-', выполняющей изменение знака рациональной дроби (унарный «–»).'-', выполняющей вычитание двух рациональных дробей, либо рациональнойдроби и значения соответствующего интегрального типа.'*', выполняющей умножение одной рациональной дроби на другую, либорациональной дроби на значение соответствующего интегрального типа.'/', выполняющей деление одной рациональной дроби на другую, либорациональной дроби на значение соответствующего интегрального типа.'=', выполняющей присваивание рациональной дроби значения другойрациональной дроби, либо значения соответствующего интегрального типа.'+=', выполняющей увеличение рациональной дроби на рациональное значение,либо на значение соответствующего интегрального типа.499.'-=', выполняющей уменьшение рациональной дроби на рациональное значение,либо на значение соответствующего интегрального типа.'*=', выполняющей присваивание с умножением рациональных дробей, либос умножением рациональной дроби на значение соответствующегоинтегрального типа.'/=', выполняющей присваивание с делением рациональных дробей, либос делением рациональной дроби на значение соответствующегоинтегрального типа.'==', выполняющей сравнение двух рациональных дробей, либо сравнениерациональной дроби со значением соответствующего интегрального типа.'!= ', выполняющей сравнение двух рациональных дробей, либо сравнениерациональной дроби со значением соответствующего интегрального типа.'<', выполняющей сравнение двух рациональных дробей, либо сравнениерациональной дроби со значением соответствующего интегрального типа.'>', выполняющей сравнение двух рациональных дробей, либо сравнениерациональной дроби со значением соответствующего интегрального типа.'<=', выполняющей сравнение двух рациональных дробей, либо сравнениерациональной дроби со значением соответствующего интегрального типа.'>=', выполняющей сравнение двух рациональных дробей, либо сравнениерациональной дроби со значением соответствующего интегрального типа.увеличения '++', выполняющей увеличение на 1 значения рациональной дроби.уменьшения '--', выполняющей уменьшение на 1 значения рациональной дроби.'<<', выполняющей вывод в текстовый поток значения рациональной дробив виде «числитель/знаменатель».других операций, представляющихся полезными при работе с рациональнымидробями.STL9.1.
Дать определение контейнера. Каково назначение контейнеров?9.2. Перечислить основные контейнеры библиотеки STL.9.3. Какие виды итераторов допускают контейнеры vector и list?9.4. Какие виды операций сравнения итераторов допустимы для этих контейнеров?9.5. Дать определение итератора.9.6. Какие категории итераторов определены в STL?Чем отличаются друг от друга итераторы разных категорий?9.7. Чем различаются прямые и обратные итераторы?Привести пример использования обратного итератора.Какие виды итераторов допускают обратные итераторы?509.8. Какие виды операций сравнения итераторов допустимы для двунаправленныхитераторов?Привести пример ошибочного использования двунаправленного итератора.9.9.
Сравнить возможности, предоставляемые двунаправленным итератором и итератором произвольного доступа.9.10. Перечислить типы итераторов библиотеки STL, допускающих использованиев многопроходных алгоритмах.Сравнить наборы операций, предоставляемые одно- и двунаправленными итераторами.Привести по одному примеру ошибочного использования одно- и двунаправленных итераторов.9.11. Верно ли решена задача: «Описать функцию, суммирующую значения элементовсписка, стоящих на нечетных местах, считая, что элементы списка нумеруютсяс 1»? Если есть ошибки, объясните, в чем они заключаются и как их исправить.#include <iostream>#include <list>using namespace std;int main ()int g (list <int> & lst){int S=0;list<int> :: iterator p = lst.begin();while (p != lst.end()){ S += * p; p += 2;}return S;};9.12.