C++程序设计教程第二版课件C++程序设计教程6章节幻灯片.pptVIP

C++程序设计教程第二版课件C++程序设计教程6章节幻灯片.ppt

  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文档。上传文档
查看更多
* * 分别排序,直接加以字串比较是直截了当的思路: for ( string s,t; inst; ) { sort ( s.begin ( ), s.end ( ) ) ; sort ( t.begin ( ), t.end ( ) ) ; cout( s==t ? yes\n : no\n ) ; } C++标准算法 * * 避免排序,分别统计两个字串中01的个数则性能更优: ( 排序至少做O(nlogn)数量级运算,统计只做O(n)数量级运算 ) for ( string s,t; inst; ) { int s1=count(s.begin(), s.end(), ’1’); int s0=count(s.begin(), s.end(), ’0’); int t1=count(t.begin(), t.end(), ’1’); int t0=count(t.begin(), t.end(), ’0’); cout(s1==t1 s0==t0 ? yes\n : no\n); } C++标准算法 * * 字串中非0即1的特征,可以避免多余的统计,进一步提高性能: for ( string s,t; inst; ) { int s1=count ( s.begin(), s.end(), ’1’) ; int t1=count ( t.begin(), t.end(), ’1’) ; cout (s1==t1 s.length()==t.length() ? yes\n : no\n); } C++标准算法 * * 6. 动态内存 ( Dynamic Memory ) 揭示:许多问题不知道数据量的大小,需要所运用的数据结构具有扩容能力;许多问题要求时间性能甚于空间占用.充分利用堆空间(动态内存)是解决这些问题的关键 做法:理解堆空间的使用场合,学习堆空间的使用方法 * * 使用容器,便是自动使用堆内存 例如,从abc.txt中读取诸段落: ifstream in ( abc.txt ) ; vectorstring ps ; // ps.reserve(1100) ; 可以预留 for ( string s ; getline ( in, s ) ; ) ps.push_back(s) ; 预留是减小频繁扩容造成的数据移动开销 * * 若每个数据的处理,都要用到已经处理的数据时,保存历史数据,则可以改善时间性能 例如,统计一亿之内的素数个数(原始版): bool isPrime(int n){ int sqrtn=sqrt(n*1.0); for(int i=2; i=sqrtn; ++i) if(n%i==0) return false; return true; }//-------------------------- int main(){ int num=0; for(int i=2; i=100000000; ++i) if(isPrime(i)) num++; coutnumendl; }//-------------------------- * * 空间换时间版 int main() { bitset100000000* p = new bitset100000000; p-set(); for(int i=2; i=10000; ++i) if(p-test(i)) for(int j=i*i; jp-size(); j+=i) p-reset(j); int num=0; for(int i=2; i100000000; ++i) if(p-test(i)) num++; coutnumendl; delete[] p; } 在空间中统计 完成每个 元素的标记 * * 7. 低级编程 ( Lower Programming ) 揭示:通过无原则的代码优化来简化程序的执行步骤,从而提高性能.它会影响可读性,并需要对程序的内存布局有深刻的了解,这一般是编程课的后继学习内容 做法:尽量去掉组织程序所花费的代价:少用调用频繁的函数;通过指针间访数据;尽可能不用类;无原则数据共享;用C库不用C++库 * * 低级编程版: 逐一读入两个01字串,比较是否含有相同元素 int cnt(char* a){ int num=0; while(*a) if(*a

文档评论(0)

精品课件 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档