C++程序设计教程6 第六章 节 性能.pptVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
C++程序设计教程6 第六章 节 性能.ppt

C++程序设计教程(第二版);提高性能的意义: 性能对提高编程能力举足轻重 如何提高性能?   以合理使用资源为前提,尽快完成任务的能力称为效率.效率影响性能,提高效率就能提高性能 学习目标: 1. 扩展视野,对同一问题的不同要求,模仿各种编程技巧与空间布局策略,予以应对.从而对各种不同的问题,亦能应变自如 2. 掌握测试性能的方法,学会测算时/空交换的代价,客观评估自身的编程能力;第六章内容;1. 内联函数 ( Inline Functions );//================================== #includeiostream bool isDigit(char); // 小函数 int main( ){ for(char c; cinc c!=\n; ) if(isDigit(c)) std::cout“Digit.\n; else std::cout“NonDigit.\n; }//--------------------------------- bool isDigit(char ch){ return ch=0 ch=9 ? 1 : 0; }//=================================;内联函数的使用经验:;//====================================== #includeiostream #includetime using namespace std; //-------------------------------------- int calc1(int a, int b){ return a+b; } inline int calc2(int a, int b){ return a+b; } //-------------------------------------- int main(){ int x[1000], y[1000], z[1000]; clock_t t = clock(); for(int i=0; i1000*1000*1000; ++i) z[i] = calc1(x[i%1000], y[i%1000]); cout(clock()-t)/CLK_TCK“without inline\n; t = clock(); for(int i=0; i1000*1000*1000; ++i) z[i] = calc2(x[i%1000], y[i%1000]); cout(clock()-t)/CLK_TCK“with inline\n; }//=====================================;结果分析: 内联用与不用差很多 结论: 应尽量将函数改造成可内联性质,提高性能;2. 数据结构 ( Data Structures );问题:;采用不同的数据结构;栈方式;向量方式;结论;3. 算法 ( Algorithms );问题:;算法1:递归法 优点:算法简单,容易编程 缺点:栈空间负担过重,调用开销过大;算法2:迭代法 优点:节省空间,节省时间  缺点:编程相对复杂;算法3:向量迭代法 优点:节省时间 缺点:n越大,占用堆空间越多;算法4:直接计算法 优点:节省时间 缺点:引入了浮点计算;fibo1:只在示意性编程中使用,但并不是否定一切递归法 fibo2:在讲究性能的场合中使用,它省空间省时间,但在n很大的场合中,性能比不上fibo4 fibo3:可以数组代替向量,提高低级编程的性能,它易编易用,还可以读取中间项的值,但在一味追求性能的场合中,比不上fibo2 fibo4:在n不太大时,与fibo2相当,在n趋向很大时,其性能优势便充分体现;4. 数值计算 ( Numerical Computation );数值计算的参数描述;矩形法;辛普生法 ;性能比较;5. 标准C++ 算法 ( Standard C++ Algorithms );容器的区间表示;逐一读入两个01字串,比较是否含有相同元素;分别排序,直接加以字串比较是直截了当的思路:;避免排序,分别统计两个字串中01的个数则性能更优: ( 排序至少做O(nlogn)数量级运算,统计只做O(n)数量级运算 );字串中非0即1的特征,可以避免多余的统计,进一步提高性能:;6. 动态内存 ( Dynamic Memory );使用容器,便是自动使用堆内存;若每个数据的处理,都要用到已经处理的数据时,保存历史数据,则可以改善时间性能;空间换时间版;7. 低级编程

您可能关注的文档

文档评论(0)

yuzongxu123 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档