c++模板及应用习题答案.docx

上传人:小飞机 文档编号:3153662 上传时间:2023-03-11 格式:DOCX 页数:11 大小:40.23KB
返回 下载 相关 举报
c++模板及应用习题答案.docx_第1页
第1页 / 共11页
c++模板及应用习题答案.docx_第2页
第2页 / 共11页
c++模板及应用习题答案.docx_第3页
第3页 / 共11页
c++模板及应用习题答案.docx_第4页
第4页 / 共11页
c++模板及应用习题答案.docx_第5页
第5页 / 共11页
亲,该文档总共11页,到这儿已超出免费预览范围,如果喜欢就下载吧!
资源描述

《c++模板及应用习题答案.docx》由会员分享,可在线阅读,更多相关《c++模板及应用习题答案.docx(11页珍藏版)》请在三一办公上搜索。

1、c+模板及应用习题答案1.概念填空题 1.1 C+最重要的特性之一就是代码重用,为了实现代码重用,代码必须具有 通用性 。通用代码需要不受数据 类型 的影响,并且可以自动适应数据类型的变化。这种程序设计类型称为 参数化 程序设计。模板是C+支持参数化程序设计的工具,通过它可以实现参数化 多态性 性。 1.2函数模板的定义形式是template 返回类型 函数名(形式参数表)。其中,中参数可以有 多 个,用逗号分开。模板参数主要是 模板类型 参数。它代表一种类型,由关键字 typename 或 class 后加一个标识符构成,标识符代表一个潜在的内置或用户定义的类型参数。类型参数由可以是任意合法

2、标识符。C+规定参数名必须在函数定义中至少出现一次。 1.3编译器通过如下匹配规则确定调用那一个函数:首先,寻找最符合 函数名 和 参数类型 的一般函数,若找到则调用该函数;否则寻找一个 函数模板 ,将其实例化成一个 模板函数 ,看是否匹配,如果匹配,就调用该 模板函数 ;再则,通过 类型转换 规则进行参数的匹配。如果还没有找到匹配的函数则调用错误。如果有多于一个函数匹配,则调用产生 二义性 ,也将产生错误。 1.4类模板使用户可以为类声明一种模式,使得类中的某些数据成员、某些成员函数的参数、某些成员函数的返回值能取 任意类型 。类是对一组对象的公共性质的抽象,而类模板则是对不同类的 数据类型

3、? 的抽象,因此类模板是属于更高层次的抽象。由于类模板需要一种或多种 类型 参数,所以类模板也常常称为 参数化类 。 2. 简答题 2.1简述函数模板生成函数的过程。 2.2 简述类模板生成对象的过程。 2.3 简述函数模板与模板函数、类模板与模板类的区别。 3. 选择题 3.1关于函数模板,描述错误的是。 A.函数模板必须由程序员实例化为可执行的函数模板 B.函数模板的实例化由编译器实现 C.一个类定义中,只要有一个函数模板,则这个类是类模板 D.类模板的成员函数都是函数模板,类模板实例化后,成员函数也随之实例化 3.2下列的模板说明中,正确的是。 A.template B.template

4、 C.template D.template 3.3 函数模板定义如下: template Max( T a, T b ,T &c)c=a+b; 下列选项正确的是。 A. int x, y; char z; B.double x, y, z; Max(x, y, z); Max( x, y, z); C.int x, y; float z; D.float x; double y, z; Max( x, y, z); Max( x,y, z); 3.4 下列有关模板的描述错误的是(D)。 A 模板把数据类型作为一个设计参数,称为参数化程序设计。 B 使用时,模板参数与函数参数相同,是按位置而不

5、是名称对应的。 C 模板参数表中可以有类型参数和非类型参数。 D 类模板与模板类是同一个概念。 3.5类模板的使用实际上是将类模板实例化成一个。 A函数 B对象 C类 D抽象类 3.6类模板的模板参数。 A只能作为数据成员的类型 B只可作为成员函数的返回类型 C只可作为成员函数的参数类型 D以上三种均可 3.7类模板的实例化。 A在编译时进行 B属于动态联编 C在运行时进行 D在连接时进行 3.8以下类模板定义正确的为。 Atemplate 4编程题 4.1设计一个函数模板,其中包括数据成员T an以及对其进行排序的成员函数 sort( ),模板参数T可实例化成字符串。 #include #i

6、nclude using namespace std; templatevoid Sort(T* a,int n) int i,j; T t; for(i=0;in-1;i+) for(j=0;jaj+1) Btemplate Dtemplate Ctemplate t=aj; aj=aj+1; aj+1=t; templatevoid Print(T* a,int n) int i; for(i=0;in;i+) coutai ; coutendl; int main string Str10=Zhang,Li,Wang,Qian,Zhao,Wu,Xu,Tang,Shen,Liang; 4.

7、2设计一个类模板,其中包括数据成员T an以及在其中进行查找数据元素的函数int search(T)模板参数 T可实例化成字符串。 #include using namespace std; templateclass A int size; T* element; public: A; A; int Search(T); void SetElement(int index,const T& value); ; templateA:A size=n1? n:1; element=new Tsize; templateA:A delete element; templateint A:Searc

8、h(T t) int i; for(i=0;isize;i+) if(elementi=t) return i; return -1; int Int8=20,12,0,-5,9,-18,6,11; double Dou7=3.07,8.12,-0.45,6,10,-9,7.29; Sort(Str,10); Sort(Int,8); Sort(Dou,7); Print(Str,10); Print(Int,8); Print(Dou,7); return 0; templatevoid A:SetElement(int index,const T& value) elementindex=

9、value; int main A intAry; /用int实例化,建立模板类对象 A douAry;/用double实例化,建立模板类对象 int i; for(i=0;i5;i+) intAry.SetElement(i,i+3); for(i=0;i=0)couti=0)coutiendl; return 0; 4.3设计一个单向链表类模板,节点数据域中数据从小到大排列,并设计插入、删除节点的成员函数。 #include using namespace std; templateclass List; templateclass Node T info; /数据域 Node *link

10、; /指针域 public: Node; /生成头结点的构造函数 Node(const T & data);/生成一般结点的构造函数 friend class List; ; template Node:Nodelink=NULL; template Node:Node(const T & data) info=data; link=NULL; /定义链表类 templateclass List Node *head; /链表头指针和尾指针 public: List; /构造函数,生成头结点(空链表) List; /析构函数 void MakeEmpty; /清空一个链表,只余表头结点 Nod

11、e* Find(T data); /搜索数据域与data相同的结点,返回该结点的地址 void PrintList; /打印链表的数据域 void InsertOrder(Node *p); /按升序生成链表 Node* CreatNode(T data); /创建一个结点(孤立结点) Node* DeleteNode(Node* p); /删除指定结点 ; templateList:List head=new Node(-9999);/头结点,最小的数据从小到大插入 templateList:List MakeEmpty; delete head; templatevoid List:Mak

12、eEmpty Node *tempP; while(head-link!=NULL) tempP=head-link; head-link=tempP-link; /把头结点后的第一个节点从链中脱离 delete tempP; /删除(释放)脱离下来的结点 template Node* List:Find(T data) Node *tempP=head-link; while(tempP!=NULL & tempP-info!=data) tempP=tempP-link; return tempP; /搜索成功返回该结点地址,不成功返回NULL templatevoid List:Prin

13、tList Node* tempP=head-link; while(tempP!=NULL) coutinfolink; coutendl; templatevoid List:InsertOrder(Node *p) Node *tempP=head,*tempQ=head; /tempQ指向tempP前面的一个节点 while(tempP!=NULL) templateNode* List:CreatNode(T data)/建立新节点 Node*tempP=new Node(data); return tempP; if(p-infoinfo)break; /找第一个比插入结点大的结点

14、,由tempP指向 tempQ=tempP; tempP=tempP-link; p-link=tempP; tempQ-link=p; templateNode* List:DeleteNode(Node* p) Node* tempP=head-link,*tempQ=head,*tempC; while(tempP!=NULL & tempP!=p) tempQ=tempP; tempP=tempP-link; tempC=tempP; tempQ-link=tempP-link; return tempC; int main Node * P1; List list1; int a10

15、=20,12,0,-5,9,-18,6,11,5,3,i,j; for(i=0;i10;i+) P1=list1.CreatNode(ai); list1.InsertOrder(P1); list1.PrintList; cout请输入一个要求删除的整数j; P1=list1.Find(j); if(P1!=NULL) P1=list1.DeleteNode(P1); delete P1; list1.PrintList; else cout未找到endl; cout请输入一个要求插入的整数j; P1=list1.CreatNode(j); list1.InsertOrder(P1); li

16、st1.PrintList; list1.MakeEmpty;/清空list1 list1.PrintList; return 0; 4.4 为单链表类模板增加一个复制构造函数和赋值运算符(=)。 在上题基础上,List类增加一个复制构造函数和赋值运算符(=) templateList:List(List& l) head=new Node(-9999);/现建立头结点 Node* tempP=l.head-link,*tempC; while(tempP!=NULL) tempC=CreatNode(tempP-info); InsertAfter(tempC); tempP=tempP-l

17、ink; templateList& List:operator=(List& l) MakeEmpty;/先释放原来链表的数据结点 Node* tempP=l.head-link,*tempC; while(tempP!=NULL) int main Node * P1; List list1,list2; int a10=20,12,0,-5,9,-18,6,11,5,3,i,j; for(i=0;i10;i+) P1=list1.CreatNode(ai); list1.InsertOrder(P1); list1.PrintList; cout请输入一个要求删除的整数j; P1=lis

18、t1.Find(j); if(P1!=NULL) P1=list1.DeleteNode(P1); delete P1; tempC=CreatNode(tempP-info); InsertAfter(tempC); tempP=tempP-link; return *this; list1.PrintList; else cout未找到endl; cout请输入一个要求插入的整数j; P1=list1.CreatNode(j); list1.InsertOrder(P1); list1.PrintList; list2=list1; list2.PrintList; List list3=list1; list3.PrintList; cout请输入一个要求删除的整数j; P1=list1.Find(j); if(P1!=NULL) P1=list1.DeleteNode(P1); delete P1; list1.PrintList; else cout未找到endl; list2=list3=list1; list2.PrintList; list3.PrintList; list1.MakeEmpty;/清空list1 list2.MakeEmpty;/清空list1 list3.MakeEmpty;/清空list1 return 0;

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 生活休闲 > 在线阅读


备案号:宁ICP备20000045号-2

经营许可证:宁B2-20210002

宁公网安备 64010402000987号