C++实验介绍.doc

  1. 1、本文档共16页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
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)

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

我是自由职业者,从事文档的创作工作。

1亿VIP精品文档

相关文档