Chinaunix首页 | 论坛 | 博客
  • 博客访问: 578662
  • 博文数量: 79
  • 博客积分: 2513
  • 博客等级: 少校
  • 技术积分: 806
  • 用 户 组: 普通用户
  • 注册时间: 2006-10-04 18:46
文章分类

全部博文(79)

文章存档

2014年(1)

2010年(5)

2009年(8)

2008年(11)

2007年(41)

2006年(13)

我的朋友

分类: C/C++

2007-10-14 23:15:00

  搜索关于 STL 中排列 permutation 的时候,发现一个说到 VC  的实现的 bug 的网页,“用next_permutation()生成r-组合数,兼发现VC7的一个bug”(http://blog.csdn.net/Solstice/archive/2002/10/21/2059.aspx)。没想到这个情况也被我碰到了。

  我是在用 permutation 实现顺序敏感的组合 order_combination 时碰到的。VC 2003 sp1 中,对存在相同元素的序列 [6, 5, 4, 1, 1, 3] 调用 prev_permutation,得到的结果是 [6, 5, 4, 1, 3, 1],而正确的结果应该是 [6, 5, 3, 4, 1, 1]

  同样的代码在 Dev-C++ 4.9.9.2 中测试则不会出现问题。所以是 VC 2003 sp1 的 bug 无疑了。

  解决办法:将 include 目录下的 algorithm 文件中 prev_permutation 非谓词版本的

if (!(*--_Next < *_Next1))

替换为:

if (*_Next1 < *--_Next)


将 prev_permutation 的谓词版本的

if (!_Pred(*--_Next, *_Next1))

替换为:

if (_Pred(*_Next1, *--_Next))


  其实都是把两个比较的两个元素的顺序调换,再去掉 ! 逻辑非运算符;也就是“不小于”变成“大于”。

阅读(1420) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~