网站大量收购独家精品文档,联系QQ:2885784924

C++引用习题教案.doc

  1. 1、本文档共10页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
01.分析以下程序的执行结果 #includeiostream.h void main() { int a; int b=a; // 变量引用 b=10; couta=aendl; } 解: 本题说明变量引用的方法。b是a的引用,它们分配相同的空间,b的值即为a的值。 所以输出为 a=10。 注意:引用是引入了变量或对明的一个 义词,引用不产生对象的副本。 ----------------------------------------------------------------- 02.分析以下程序的执行结果 #includeiostream.h class Sample { int x; public: Sample(){}; Sample(int a){x=a;} Sample(Sample a){x=a.x+1;} void disp(){coutx=xendl;} }; void main() { Sample s1(2),s2(s1); s2.disp(); } 解: 本题说明类拷贝构造函数的使用方法。Sample类的Sample(Sample a)构造函数是一个拷贝构造函数,将a对象的x值赋给当前对象的x后加1。 所以输出为:x=3。 ----------------------------------------------------- 03.编写程序,调用传递引用的参数,实现两个字符串变量的交换。 例如开始: char *ap=hello; char *bp=how are you?; 交换的结果使得ap和bp指向的内容分别为: ap: how are you? bp: hello 解: 本题使用引用调用(实现由于字符串指针本身就是地址,这里可不使用引用参数,效果是一样的)。 程序如下: #includeiostream.h #includestring.h void swap(char *x,char *y) // 引用作为参数 { char *temp; temp=x;x=y;y=temp; } void main() { char *ap=hello; char *bp=how are you?; coutap:apendl; coutbp:bpendl; swap(ap,bp); coutswap ap,bpendl; coutap:apendl; coutbp:bpendl; } 本程序的执行结果如下: ap:hello bp:hoe are you? swap ap,bp ap:how are you? bp:hello ----------------------------------------------------- 04.设计一个集合类Set,包括将集合置空、添加元素、判断元素是否在集合中、输出集合,以及将集合中元素逆置,另外还有一个拷贝构造函数,并使用一些数据进行测试。 解: Set类包括私有数据成员elems(存放集合元素)、pc(当前元素指针),一个默认构造函数和拷贝构造函数Set(Set s),另有成员函数empty()(将集合置空)、isempty()(判断集合是否为空)、ismemberof()(判断元素是否在集合中)、add()(添加元素)、print()(输出集合)、reverse(将集合中元素置逆)。 本题程序如下: #includeiostream.h #define Max 100 class Set { public: Set(){pc=0;} Set(Set s); // 对象引用作为参数 void empty(){pc=0;} int isempty(){return pc==0;} int ismemberof(int n); int add(int n); void print(); void reverse(); private: int elems[Max]; int pc; }; int Set::ismemberof(int n) { for(int i=0;ipc;i++) if(elems[i]==n) return 1; return 0; } int Set::add(int n) { if(ismemberof(n)) return 1; else if(pcMax) return 0; else { elems[pc++]=n; return 1; } } Set::Set(Set p) { pc=p

文档评论(0)

502992 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档