vc7.1中nth_element的一个实现优化
2006-03-29 17:51
316 查看
今天在vc7.1下写了一个小例子,测试一下nth_element和partial_sort,结果partial_sort表现正常,但nth_element的表现却很奇怪。
代码是这样的:
vector<int> v;
for (int i = 0; i < 20; i++)
v.push_back(i + 1);
random_shuffle(v.begin(), v.end());
nth_element(v.begin(), v.begin() + 5, v.end());
copy(v.begin(), v.end(), ostream_iterator<int>(cout, " "));
return 0;
按照预期,前面5个数字应该是乱序的5个,后面的也是乱序。实际上输出的却是一个全排序的结果。这让我很吃惊,立刻怀疑vc的实现有问题。结果向cber 请教,cber先问我看过14882没有?汗!我只看了MSDN。去看14882。立刻,看到,如果实现采用全排的话,复杂度约束是不可能满足的。 cber又教育我:看了源代码了吗?再次汗!去看源代码!正如侯捷所说,“源码面前,了无秘密”,原来,库的实现中有一个优化:当区间元素个数不大于32 时,直接做一次全排序,只有元素个数足够多时,才采用常规的线性复杂度算法。
从今天的事情,可以看到自己的态度仍然过于轻浮,不能踏踏实实安心学习。其实分析源代码也就是几分钟的功夫,可是潜意识一直不大喜欢Dinkumware的stl实现,所以也就比较抗拒去看它的源代码。做技术,可一定要脚踏实地啊!
鄙视自己一下!立此存照!
代码是这样的:
vector<int> v;
for (int i = 0; i < 20; i++)
v.push_back(i + 1);
random_shuffle(v.begin(), v.end());
nth_element(v.begin(), v.begin() + 5, v.end());
copy(v.begin(), v.end(), ostream_iterator<int>(cout, " "));
return 0;
按照预期,前面5个数字应该是乱序的5个,后面的也是乱序。实际上输出的却是一个全排序的结果。这让我很吃惊,立刻怀疑vc的实现有问题。结果向cber 请教,cber先问我看过14882没有?汗!我只看了MSDN。去看14882。立刻,看到,如果实现采用全排的话,复杂度约束是不可能满足的。 cber又教育我:看了源代码了吗?再次汗!去看源代码!正如侯捷所说,“源码面前,了无秘密”,原来,库的实现中有一个优化:当区间元素个数不大于32 时,直接做一次全排序,只有元素个数足够多时,才采用常规的线性复杂度算法。
从今天的事情,可以看到自己的态度仍然过于轻浮,不能踏踏实实安心学习。其实分析源代码也就是几分钟的功夫,可是潜意识一直不大喜欢Dinkumware的stl实现,所以也就比较抗拒去看它的源代码。做技术,可一定要脚踏实地啊!
鄙视自己一下!立此存照!
相关文章推荐
- 使用VC实现一个“智能”自增减线程池
- 使用VC实现一个“智能”自增减线程池
- VC实现向一个窗口发送 tab键 键盘事件
- vc中将access数据库表中的数据添加到一个ComboBox中,实现从数据库中添加ComboBox的属性
- 在vc中实现一个模访c++builder的TParameters类 (20080411更新)
- VC 实现当拖动一个文件到程序的图标上时,程序自动启动并打开该文件
- [转载]Juicer – 一个Javascript模板引擎的实现和优化
- vc++基础班[27]---实现一个简单的任务管理器
- 数据库性能优化的五种方案(mycat,基于阿里coba开源的数据库中间件,很容易实现分库分表、主从切换功能。另一个当当网开源的一个库 sharding-jdbc)
- 用VC++实现一个文本文件阅读器
- 使用VC内嵌Python实现的一个代码检测工具
- VC 一个函数实现listbox 水平滚动条
- Android上一个动画效果的实现与优化
- VC 实现程序只运行一个实例,并激活已运行的程序
- VC如何实现电脑任意一个托盘图标的隐藏
- VC++实现程序只运行一个实例 .
- 实验题7.1: 编写一个程序algo7-1.cpp,实现二叉树的各种基本运算,并在此基础上设计一个程序Main.cpp完成如下功能(b为如下图所示的一棵二叉树)
- 使用VC实现一个“智能”自增减线程池
- 转一个仿QQ界面(VC实现)