c++模板及应用习题答案.doc
《c++模板及应用习题答案.doc》由会员分享,可在线阅读,更多相关《c++模板及应用习题答案.doc(7页珍藏版)》请在咨信网上搜索。
(完整版)c++模板及应用习题答案 1。概念填空题 1.1 C++最重要的特性之一就是代码重用,为了实现代码重用,代码必须具有 通用性 .通用代码需要不受数据 类型 的影响,并且可以自动适应数据类型的变化。这种程序设计类型称为 参数化 程序设计。模板是C++支持参数化程序设计的工具,通过它可以实现参数化 多态性 性。 1.2函数模板的定义形式是template 〈模板参数表〉 返回类型 函数名(形式参数表){…}。其中,〈模板参数表〉中参数可以有 多 个,用逗号分开.模板参数主要是 模板类型 参数。它代表一种类型,由关键字 typename 或 class 后加一个标识符构成,标识符代表一个潜在的内置或用户定义的类型参数。类型参数由可以是任意合法标识符.C++规定参数名必须在函数定义中至少出现一次. 1.3编译器通过如下匹配规则确定调用那一个函数:首先,寻找最符合 函数名 和 参数类型 的一般函数,若找到则调用该函数;否则寻找一个 函数模板 ,将其实例化成一个 模板函数 ,看是否匹配,如果匹配,就调用该 模板函数 ;再则,通过 类型转换 规则进行参数的匹配.如果还没有找到匹配的函数则调用错误.如果有多于一个函数匹配,则调用产生 二义性 ,也将产生错误。 1。4类模板使用户可以为类声明一种模式,使得类中的某些数据成员、某些成员函数的参数、某些成员函数的返回值能取 任意类型 (包括 系统预定类型 和 用户自定义的类型).类是对一组对象的公共性质的抽象,而类模板则是对不同类的 数据类型? 的抽象,因此类模板是属于更高层次的抽象.由于类模板需要一种或多种 类型 参数,所以类模板也常常称为 参数化类 . 2. 简答题 2.1简述函数模板生成函数的过程。 2。2 简述类模板生成对象的过程. 2。3 简述函数模板与模板函数、类模板与模板类的区别. 3。 选择题 3。1关于函数模板,描述错误的是(A )。 A。函数模板必须由程序员实例化为可执行的函数模板 B。函数模板的实例化由编译器实现 C.一个类定义中,只要有一个函数模板,则这个类是类模板 D.类模板的成员函数都是函数模板,类模板实例化后,成员函数也随之实例化 3.2下列的模板说明中,正确的是(D )。 A.template〈typename T1,T2〉 B。template〈class T1,T2> C.template<class T1,class T2〉 D。template<typename T1,typename T2> 3。3 函数模板定义如下: template 〈typename T〉 Max( T a, T b ,T &c){c=a+b;} 下列选项正确的是(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. 使用时,模板参数与函数参数相同,是按位置而不是名称对应的。 C. 模板参数表中可以有类型参数和非类型参数。 D. 类模板与模板类是同一个概念。 3.5类模板的使用实际上是将类模板实例化成一个(C)。 A.函数 B.对象 C.类 D.抽象类 3。6类模板的模板参数(D)。 A.只能作为数据成员的类型 B.只可作为成员函数的返回类型 C.只可作为成员函数的参数类型 D.以上三种均可 3。7类模板的实例化(A)。 A.在编译时进行 B.属于动态联编 C.在运行时进行 D.在连接时进行 3。8以下类模板定义正确的为(A)。 A.template〈class T,int i=0> B.template〈class T,class int i〉 C.template〈class T,typename T〉 D.template〈class T1,T2> 4.编程题 4。1设计一个函数模板,其中包括数据成员T a[n]以及对其进行排序的成员函数 sort( ),模板参数T可实例化成字符串. #include 〈iostream> #include <string〉 using namespace std; template〈typename T〉void Sort(T* a,int n){ int i,j; T t; for(i=0;i<n-1;i++) for(j=0;j<n-i—1;j++) if (a[j]〉a[j+1]) { t=a[j]; a[j]=a[j+1]; a[j+1]=t; } } template<typename T〉void Print(T* a,int n){ int i; for(i=0;i〈n;i++) cout<〈a[i]<〈" "; cout<<endl; } int main(){ string Str[10]={”Zhang”,"Li","Wang”,”Qian”,"Zhao”,"Wu",”Xu”,”Tang”,”Shen","Liang”}; int Int[8]={20,12,0,—5,9,-18,6,11}; double Dou[7]={3。07,8。12,—0。45,6,10,-9,7.29}; Sort〈string〉(Str,10); Sort<int〉(Int,8); Sort〈double〉(Dou,7); Print(Str,10); Print(Int,8); Print(Dou,7); return 0; } 4.2设计一个类模板,其中包括数据成员T a[n]以及在其中进行查找数据元素的函数int search(T)模板参数 T可实例化成字符串。 #include 〈iostream> using namespace std; template<typename T,int n〉class A{ int size; T* element; public: A(); ~A(); int Search(T); void SetElement(int index,const T& value); }; template<typename T,int n〉A<T,n>::A(){ size=n>1? n:1; element=new T[size]; } template<typename T,int n〉A〈T,n〉::~A(){ delete [] element; } template<typename T,int n〉int A<T,n〉::Search(T t){ int i; for(i=0;i<size;i++) if(element[i]==t) return i; return —1; } template<typename T,int n>void A<T,n>::SetElement(int index,const T& value){ element[index]=value; } int main(){ A〈int,5> intAry; //用int实例化,建立模板类对象 A〈double,10> douAry;//用double实例化,建立模板类对象 int i; for(i=0;i<5;i++) intAry.SetElement(i,i+3); for(i=0;i〈10;i++) douAry。SetElement(i,(i+i)*0.35); i=intAry.Search(7); if(i〉=0)cout〈〈i〈<endl; i=douAry。Search(0.7); if(i>=0)cout〈<i〈<endl; return 0; } 4。3设计一个单向链表类模板,节点数据域中数据从小到大排列,并设计插入、删除节点的成员函数. #include〈iostream〉 using namespace std; template〈typename T>class List; template<typename T〉class Node{ T info; //数据域 Node〈T> *link; //指针域 public: Node(); //生成头结点的构造函数 Node(const T & data);//生成一般结点的构造函数 friend class List<T〉; }; template 〈typename T> Node<T〉::Node(){link=NULL;} template 〈typename T〉 Node<T>::Node(const T & data){ info=data; link=NULL; } //定义链表类 template<typename T>class List{ Node<T> *head; //链表头指针和尾指针 public: List(); //构造函数,生成头结点(空链表) ~List(); //析构函数 void MakeEmpty(); //清空一个链表,只余表头结点 Node〈T>* Find(T data); //搜索数据域与data相同的结点,返回该结点的地址 void PrintList(); //打印链表的数据域 void InsertOrder(Node〈T> *p); //按升序生成链表 Node〈T>* CreatNode(T data); //创建一个结点(孤立结点) Node〈T〉* DeleteNode(Node〈T〉* p); //删除指定结点 }; template〈typename T>List<T>::List(){ head=new Node<T〉(-9999);//头结点,最小的数据从小到大插入 } template<typename T〉List〈T>::~List(){ MakeEmpty(); delete head; } template<typename T>void List<T〉::MakeEmpty(){ Node<T> *tempP; while(head—>link!=NULL){ tempP=head-〉link; head-〉link=tempP—〉link; //把头结点后的第一个节点从链中脱离 delete tempP; //删除(释放)脱离下来的结点 } } template〈typename T> Node〈T>* List〈T>::Find(T data){ Node〈T〉 *tempP=head->link; while(tempP!=NULL && tempP->info!=data) tempP=tempP->link; return tempP; //搜索成功返回该结点地址,不成功返回NULL } template<typename T>void List<T>::PrintList(){ Node〈T>* tempP=head->link; while(tempP!=NULL){ cout〈〈tempP-〉info〈〈'\t'; tempP=tempP—〉link; } cout〈<endl; } template〈typename T>void List〈T>::InsertOrder(Node<T> *p){ Node〈T〉 *tempP=head,*tempQ=head; //tempQ指向tempP前面的一个节点 while(tempP!=NULL){ if(p—〉info〈tempP-〉info)break; //找第一个比插入结点大的结点,由tempP指向 tempQ=tempP; tempP=tempP-〉link; } p-〉link=tempP; tempQ->link=p; } template<typename T〉Node<T>* List〈T〉::CreatNode(T data){//建立新节点 Node〈T〉*tempP=new Node〈T>(data); return tempP; } template<typename T〉Node〈T>* List<T〉::DeleteNode(Node〈T>* p){ Node〈T>* 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<int〉 * P1; List<int> list1; int a[10]={20,12,0,—5,9,—18,6,11,5,3},i,j; for(i=0;i〈10;i++){ P1=list1。CreatNode(a[i]); list1。InsertOrder(P1); } list1.PrintList(); cout〈<"请输入一个要求删除的整数”<〈endl; cin>>j; P1=list1.Find(j); if(P1!=NULL){ P1=list1。DeleteNode(P1); delete P1; list1。PrintList(); } else cout<〈"未找到”<〈endl; cout〈<"请输入一个要求插入的整数"<<endl; cin>>j; P1=list1。CreatNode(j); list1.InsertOrder(P1); list1.PrintList(); list1.MakeEmpty();//清空list1 list1.PrintList(); return 0; } 4。4 为单链表类模板增加一个复制构造函数和赋值运算符(=). 在上题基础上,List类增加一个复制构造函数和赋值运算符(=) template〈typename T〉List〈T>::List(List& l){ head=new Node〈T>(—9999);//现建立头结点 Node〈T〉* tempP=l.head->link,*tempC; while(tempP!=NULL){ tempC=CreatNode(tempP->info); InsertAfter(tempC); tempP=tempP-〉link; } } template〈typename T〉List〈T〉& List〈T〉::operator=(List& l){ MakeEmpty();//先释放原来链表的数据结点 Node〈T>* tempP=l.head->link,*tempC; while(tempP!=NULL){ tempC=CreatNode(tempP—>info); InsertAfter(tempC); tempP=tempP-〉link; } return *this; } int main(){ Node〈int> * P1; List<int> list1,list2; int a[10]={20,12,0,-5,9,—18,6,11,5,3},i,j; for(i=0;i〈10;i++){ P1=list1。CreatNode(a[i]); list1。InsertOrder(P1); } list1.PrintList(); cout<〈"请输入一个要求删除的整数”<〈endl; cin〉>j; P1=list1.Find(j); if(P1!=NULL){ P1=list1。DeleteNode(P1); delete P1; list1。PrintList(); } else cout〈<"未找到"<<endl; cout<<"请输入一个要求插入的整数"〈〈endl; cin〉〉j; P1=list1。CreatNode(j); list1.InsertOrder(P1); list1。PrintList(); list2=list1; list2.PrintList(); List〈int> list3=list1; list3。PrintList(); cout<<"请输入一个要求删除的整数"<〈endl; cin>>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; }- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- c+ 模板 应用 习题 答案
咨信网温馨提示:
1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前自行私信或留言给上传者【快乐****生活】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时私信或留言给本站上传会员【快乐****生活】,需本站解决可联系【 微信客服】、【 QQ客服】,若有其他问题请点击或扫码反馈【 服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【 版权申诉】”(推荐),意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4008-655-100;投诉/维权电话:4009-655-100。
1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前自行私信或留言给上传者【快乐****生活】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时私信或留言给本站上传会员【快乐****生活】,需本站解决可联系【 微信客服】、【 QQ客服】,若有其他问题请点击或扫码反馈【 服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【 版权申诉】”(推荐),意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4008-655-100;投诉/维权电话:4009-655-100。
关于本文