- 1、本文档共30页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第14章类和对象-类属例
1. 整数集合的例子 集合类中cur size表明当前集合中有几个整数,集合中最多含max-size个整数,这两个量都由用户在执行时通过命令行参数给出。类中方法error用于处理异常情况,它是一个类理应包含的。为了使类int set更像前面所说的集成块,我们故意把方法的定义与实现分开。 //Flie set.h #include iostream.h #include stdlib.h class int_set {private: int cur_size; int max_size; int *set; void error(char *s); public: int_set(int m);//至多有m个整数 ~int_set(): int ismember(int t);//t是集合中成员? void insert(int t);//将t加入集合 void display(void);}; int set::int_set(int m) {if (m1 || nm) error(“illegal int_set size”): cur_size=0; max_size=m; set=new int[max_size]; } int_set::~int_set() {delete [max_size]set;} void int set::insert(int t) {if(++cur_sizemax_size) error(“too many elements”); int i=cur_size-1; //从当前表尾向前查找插入点 set[i]=t; while(i0set[i-1]set[i]) //将set[i]与set[i-1 ]对换 {int t=set[i]; set[i]=set[i-1]; set[i-1]=t; i--;} } int int set::ismember(int t)//二分查找 {int l=0; int u=cur_size-1; while(l=u) {int m=(l+u)/2; if (tset[m]) u=m-1; else if (tset[m]) l=m+ l; else return 1; } //找到 return 0; } //未找到 void int set::display(void) {for(int i=0;icur_size;i++) coutset[i]” ”;} void int set::error(char *s) {cout“::”s“ ” ); exit(1); } 集合类int_set的测试程序,集合中的数是随机产生的,函数randint产生一个值在集合指定范围内的随机数,main中第一个参数是集合成员个数,第二个参数是用户所希望的集合中最大数的值。 //File set.cpp #include 0set.h” #include math.h int randint(int i) //i是集合中最大数的值 {int t=rand(); if(t0) t=-t; return 1+t%i; } int main(int argc,char *argv[]) { if (argc!=3)couttwo arguments expected”: int counter=0; int m=atoi(argv[1]); int n=atoi(argv[2]); int_set s(m); //输入要求1=m=n while(counterm) {int t=randint(n); if (s.ismember(t)==0){s.insert(t); counter++; } } s.display(); retur
您可能关注的文档
- 丰田式管理本质.doc
- 自考论述题论述题.doc
- Iqwwdt化解中小企业财务管理困境的思考.doc
- 09年机、土、水毕业实践教学计划.doc
- 抢答器2010.doc
- 2.6探索勾股定理2-.ppt
- 2012年春季五一班德育工作计划.doc
- 刘鸿文(2-new).ppt
- 苏教版一年级两位数加一位数.ppt
- 必修3复习导学2.doc
- 2025年江苏省苏州市中考模拟二地理试卷(无答案).docx
- 1.5.1全称量词与存在量词(培优教学课件)-2025-2026学年高中数学必修第一册(人教A版2019).pptx
- 2025年6月四川省普通高中学业水平合格性考试历史试题(无答案).docx
- 1.5.2全称量词命题和存在量词命题的否定(培优教学课件)-2025-2026学年高中数学必修第一册(人教A版2019).pptx
- 二级短元音(课件)牛津英语自然拼读(1).pptx
- 不带括号的混合运算(课件)四年级上册数学青岛版.pptx
- Unit7ADaytoRememberSectionBwriting课件-人教版英语七年级下册.pptx
- 高中英语北师大版必修二学案Unit5RhythmPeriodThreeLesson3Exp.doc
- Unit5OldtoysPartBLet‘slearn(课件)-人教PEP版(级下册.pptx
- Unit1Inclass(1)-三年级英语下册译林版三起.pptx
文档评论(0)