手机站
网通分站
电信主站
密 码:
用户名:
当前位置 : 主页>程序设计>C/C++>列表

C 习题和解析-引用

来源:互联网 作者:west263.com 时间:2008-02-23
西部数码-全国虚拟主机10强!40余项虚拟主机管理功能,全国领先!双线多线虚拟主机南北访问畅通无阻!免费赠送企业邮局,.CN域名,自助建站480元起,免费试用7天,满意再付款! P4主机租用799元/月.月付免压金!
01.分析以下程式的执行结果
#include<iostream.h>
void main()
{
int a;
int &b=a; // 变量引用
b=10;
cout<<"a="<<a<<endl;
}
解:
本题说明变量引用的方法。b是a的引用,他们分配相同的空间,b的值即为a的值。
所以输出为 a=10。

注意:引用是引入了变量或对明的一个 义词,引用不产生对象的副本。

-----------------------------------------------------------------

02.分析以下程式的执行结果
#include<iostream.h>
class Sample
{
int x;
public:
Sample(){};
Sample(int a){x=a;}
Sample(Sample &a){x=a.x 1;}
void disp(){cout<<"x="<<x<<endl;}
};
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"
解:
本题使用引用调用(实现由于字符串指针本身就是地址,这里可不使用引用参数,效果是相同的)。
程式如下:
#include<iostream.h>
#include<string.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?";
cout<<"ap:"<<ap<<endl;
cout<<"bp:"<<bp<<endl;
swap(ap,bp);
cout<<"swap ap,bp"<<endl;
cout<<"ap:"<<ap<<endl;
cout<<"bp:"<<bp<<endl;
}
本程式的执行结果如下:
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(将集合中元素置逆)。
本题程式如下:
#include<iostream.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;i<pc;i )
if(elems[i]==n)
return 1;
return 0;
}
int Set::add(int n)
{
if(ismemberof(n))
return 1;
else if(pc>Max)
return 0;
else
{
elems[pc ]=n;
return 1;
}
}
Set::Set(Set &p)
{
pc=p.pc;
for(int i=0;i<pc;i )
elems[i]=p.elems[i];
}
void Set::print()
{
cout<<"{";
for(int i=0;i<pc-1;i )
cout<<elems[i]<<",";
if(pc>0)
cout<<elems[pc-1];
cout<<"}"<<endl;
}
void Set::reverse()
{
int n=pc/2;
for(int i=0;i<n;i )
{
int temp;
temp=elems[i];
elems[i]=elems[pc-i-1];
elems[pc-i-1]=temp;
}
}
void main()
{
Set A;
cout<<"A是否为空:"; cout<<A.isempty()<<endl;
cout<<"A:"; A.print();
Set B;
for(int i=1;i<=8;i )
B.add(i);
cout<<"B:"; B.print();
cout<<"5是否在B中:"; cout<<B.ismemberof(5)<<endl;
B.empty();
for(int j=11;j<20;j )
B.add(j);
Set C(B);
cout<<"C:"; C.print();
C.reverse();
cout<<"C逆置"<<endl;
cout<<"C:"; C.print();
}
本程式执行结果如下:
A是否为空:1
A:{}
B:{1,2,3,4,5,6,7,8}
5是否在B中:1
C:{11,12,13,14,15,16,17,18,19}
C逆置
C:{19,18,17,16,15,14,13,12,11}

[1] [2] [3] [4] 下一页




文章整理:西部数码--专业提供域名注册虚拟主机服务
http://www.west263.com
以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

热点关注
IDC资讯 虚拟主机 域名注册 托管租用 vps主机 智能建站
网站运营 建站经验 策划盈利 搜索优化 网站推广 免费资源
网站联盟 联盟新闻 联盟介绍 联盟点评 网赚技巧
行业资讯 业界动态 搜索引擎 网络游戏 门户动态 电子商务 广告传媒
网络编程 Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术 Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷 Internet Explorer
网页制作 FrontPages Dreamweaver Javascript css photoshop fireworks Flash
程序设计 Java技术 C/C++ VB delphi
网络知识 网络协议 网络安全 网络管理 组网方案 Cisco技术
操作系统 Win2000 WinXP Win2003 Mac OS Linux FreeBSD
返回首页 |关于我们 | 联系我们 | 付款方式 | 创业联盟 | 价格总览 | 资讯中心 | 友情链接 | 网站地图 | 招贤纳士 | RSS