- 1、本文档共50页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第八章 C++实用技巧与模版库 在本章中将介绍各种各样实用的提高我们编程效率的小技巧和模版库。其中绝大多数依靠C++自带类和函数实现。 第一节 排序算法 排序算法为竞赛中最常用的算法之一,我们可以利用C++自带的库函数进行排序。 使用排序算法必须包含 algorithm 头文件 自带排序算法的一般形式为: //将数组arr的下标为m的元素到下标为n-1的元素进行从小到大排序 sort(arr+m,arr+n); sort(arr+m,arr+n,comp); //与sort(arr+m,arr+n); 相比,这个 //写法可以自己定义排序的规则 //其中,comp为自定义的函数 对于sort(arr+m,arr+n) 我们举个简单的例子: //这个程序实现从键盘读入10个数,然后从小到大输出的功能 #includeiostream #includealgorithm using namespace std; int a[10]; int main() { for (int i=0;i10;++i) cina[i]; sort(a+0,a+10); for (int i=0;i10;++i) couta[i] ; coutendl; return 0; } 当然,有时我们需要从大到小的进行排序。那么我们可以用 sort(arr+n,arr+m,comp)进行排序。 不过,在调用sort(arr+n,arr+m,comp) 之前我们需要自己写个 comp函数。 从大到小排序的comp函数可以这样写: int my_comp(const int a,const int b) { return ab; //在两元素相同时一定要返回 0 或者 false } //comp函数的名字是由我们自己决定的,例如可以叫 //cat_cat,dog_dog 等等 //程序实现从键盘读入10个数,然后从大到小输出的功能 #includeiostream #includealgorithm using namespace std; int a[10]; int my_comp(const int a,const int b) { return ab; //如果ab 则返回1 ,否则返回 0 } int main() { for (int i=0;i10;++i) cina[i]; sort(a+0,a+10,my_comp); for (int i=0;i10;++i) couta[i] ; coutendl; return 0; } 在更多情况下,我们不仅对一个特征进行排序,而是多个特征。例如将学生的成绩进行排序,当然用上面的做法是行不通的。这时,我们就想到了结构体这种数据类型。当我们采用sort()函数的默认规则排序结构体时,sort()默认结构体中的第一个成员为第一关键字,第二个成员为第二关键字,……,第N个元素为第N关键字,然后从小到大排序。 例如我们要将学生的成绩从大到小排序,当成绩相同时,根据姓名字典序小的优先的规则排进行序。显然我们无法采用默认规则进行排序。 这时我们可以定义这样的comp: int score_comp(const student a,const student b) { if (a.scoreb.score) return 1; if (a.scoreb.score) return 0; if (a.nameb.name) return 1; return 0; } 例8.1 每当考试结束,老师总要对学生的成绩进行排序,以便研究学生学习情况。老师发现学生数目庞大,所以找来了会编程的你,并且它给你了全部同学的分数,希望你能按如下规则排序:1.分数高的排在前面;2.如果分数相同,就把名字字典序低的放在前面。 【输入格式】 第一行一个整数n 接下来n行每行一个学生名字和一个分数。 【输出格式】 每行一个名字和一个分数 【输入样例】 3 Xiaoxiao 396 Yingmo 405 Diyucailang 399 【输出样例】 Yingm
您可能关注的文档
- 第7章轴向拉伸与压缩.ppt
- 第7讲 随机变量函数的分布2016.ppt
- 第7章计算机多媒体设备.ppt
- 第7章脊髓疾病诊断治疗.ppt
- 第7讲三角函数模型及应用.ppt
- 第7章现金流量表分析.ppt
- 第7节、收获的季节.ppt
- 第7课《在烈日和暴雨下》(定用)ppt.ppt
- 第7课 大变革的时代.ppt
- 第7课《戊戌变法》PPT课件.ppt
- 初中技术课堂中创客教育对学生创新能力的培养探讨教学研究课题报告.docx
- 高中政治议题探究教学中学生参与度提升策略教学研究课题报告.docx
- 高中生物“深度学习”策略在生态学教学中的应用研究教学研究课题报告.docx
- 高中历史课程中历史思维能力的教学策略研究教学研究课题报告.docx
- 小学体育课程运动技能训练方案设计教学研究课题报告.docx
- 初中数学建模活动对学生问题解决能力的培养与实践探究教学研究课题报告.docx
- 初中美术课堂中素描训练对学生素描技法的提高研究教学研究课题报告.docx
- 小学科学动手实践自制机器人对创新能力的激发教学研究课题报告.docx
- 初中化学:钙钛矿太阳能电池材料制备过程中的溶剂选择与优化教学研究课题报告.docx
- 小学美术课堂中色彩搭配的艺术表现与情感传达教学研究课题报告.docx
最近下载
- 译林英语五年级下册期中试卷.doc VIP
- 武汉市2025届高中毕业生二月调研考试(二调)数学试卷(含答案详解).pdf
- 2023年北京市西城区中考地理会考试卷.docx
- 基于ansys有限元分析法的无人机起落架结构设计和静力分析.docx
- 产业用地M9可卖80%,可配住宅.pdf
- 推进高校“一站式”学生社区建设.docx VIP
- syb创业培训第五步选择一种企业法律形态.pptx VIP
- DBJ_T 15-88-2022 建筑幕墙可靠性鉴定技术规程.docx
- 课题开题报告:数智化一站式学生社区建设赋能高校新质人才培养的路径研究与实践.docx VIP
- 贝壳房屋买卖合同范本2024年.docx
文档评论(0)