用C++命令统计树

use*_*288 17 c++ algorithm stl data-structures

我需要一个标准GCC STL地图容器的订单统计树.

我查了一下,有一些叫做PBDS的东西.基于策略的数据结构.这种用法对我来说也不清楚.

任何人都可以告诉我如何使用STL地图容器的订单统计树?即使它只在GNU G ++上足够吗?

Evg*_*uev 19

以下是作为订单统计树实现的基于GNU策略的STL MAP的示例(在Linux gcc 4.6.1上测试):

#include <iostream>
#include <ext/pb_ds/assoc_container.hpp>
#include <ext/pb_ds/tree_policy.hpp>

using namespace std;
using namespace __gnu_pbds;

typedef
tree<
  int,
  int,
  less<int>,
  rb_tree_tag,
  tree_order_statistics_node_update>
map_t;

int main()
{
  map_t s;
  s.insert(make_pair(12, 1012));
  s.insert(make_pair(505, 1505));
  s.insert(make_pair(30, 1030));
  cout << s.find_by_order(1)->second << '\n';
  return 0;
}
Run Code Online (Sandbox Code Playgroud)

以下是GNU基于策略的数据结构概述的链接.这是其他tree_order_statistics示例.我找不到基于策略的数据结构的良好参考,但您可以使用这些链接以及PBDS源.

  • 请注意,如果我们为 `tree&lt;..&gt;` 的第二个模板参数指定 `null_type`,我们将得到一个订单统计数据集。 (2认同)