- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
C++课程实验报告
1340601119 林子扬
1.试定义一个类STR,实现求两个字符串的交集。两个字符串的交集是指同时属于两个字符串的字符的集合,且该集合中的字符各不相同。具体要求如下:
(1)私有数据成员: char s1[50],s2[50],s0[50];字符串s0用于存放字符串s1和字符串s2的交集。
(2)公有成员函数:
● STR(char *p1,char *p2);构造函数,分别用参数p1和p2初始化成员数组s1和s2。
● int isin(char *p,char c);判断字符c是否出现在字符串p中,如果是,则返回值为1,否则返回0。
● void fun();求成员数组s1和s2的交集,并将结果存放在成员数组s0中。提示:利用函数isin(char *,char)依次判断一个字符串中的每个字符是否包含于另一个字符串中,如果包含,且该字符不包含于成员数组s0中,则将该字符加入到成员数组s0中。
● void print();按输出示例的格式输出所有数据成员。
(3)在主函数中对该类进行测试。
输出示例:
字符串1:abcdef123abc12
字符串2:acef123ace124
两个字符串的交集:acef123
源程序代码:
#includeiostream.h
#includestring.h
class STR{
char s0[50],s1[50],s2[50];
public:
STR(char *p1,char *p2);
int isin(char *p,char c);
void fun();
void print();
};
STR::STR(char *p1,char *p2)
{
strcpy(s1,p1);
strcpy(s2,p2);
s0[0]=\0;
}
int STR::isin(char *p,char c)
{
char *p0=p;
while(*p0)
{
if(*p0++==c) return 1;//后置自增参与后指向下一位
}
return 0;
}
void STR::fun()
{
char *p0=s0,*p1=s1;
while(*p1){
if(isin(s2,*p1)(!isin(s0,*p1)))
{
*p0++=*p1;
}
*p0=\0;
p1++;
}
/*for(char *p1=s1,*p0=s0;*p1;p1++) {
if(isin(s2,*p1)(!isin(s0,*p1)))
*p0++=*p1;
*p0=\0;
}*/
}
void STR::print()
{
cout字符串1:s1endl;
cout字符串2:s2endl;
cout两个字符的交集:s0endl;
}
void main()
{
char str1[]=abcdef123abc12;
char str2[]=acef123ace124;
STR t(str1,str2);
t.fun();
t.print();
}
运行结果:
2.试定义一个类Array,实现由一个数组派生出另一个数组。派生规则如下:新数组的元素取值为原数组中相同位置元素的左、右两个相邻元素前后拼接后形成的整数(左邻元素在前,右邻元素在后)。规定最左(右)列元素的左(右)邻元素为该元素所在行的最右(左)侧的元素。具体要求如下:
(1)私有数据成员:
● int a [3][4]; 原数组。
● int b [3][4]; 派生数组。
(2) 公有成员函数
● Array(int t[][4],int n);构造函数,利用参数t的前n行元素初始化数据成员a。
● int nn(int t1,int t2);返回t1,t2拼接后形成的整数(t1在前,t2在后)。
● void fun();按题意生成新数组,并将结果存放到数据成员b中。
● void print();按矩阵形式输出成员数组。
(3)在主函数中对该类进行测试。
输出示例:
原数组:
41 67 34 0
69 24 78 58
62 64 5 45
派生数组:
67 4134 670 3441
5824 6978 2458 7869
4564 625 6445 562
源程序代码:
#includeiostream.h
#includestring.h
cla
原创力文档


文档评论(0)