⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 nary_union.h

📁 很多二维 三维几何计算算法 C++ 类库
💻 H
字号:
// Copyright (c) 1997-2002  Max-Planck-Institute Saarbruecken (Germany).// All rights reserved.//// This file is part of CGAL (www.cgal.org); you may redistribute it under// the terms of the Q Public License version 1.0.// See the file LICENSE.QPL distributed with CGAL.//// Licensees holding a valid commercial license may use this file in// accordance with the commercial license agreement provided with the software.//// This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE// WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.//// $URL: // $Id: // //// Author(s)     :     Peter Hachenberger  <hachenberger@mpi-sb.mpg.de>#ifndef CGAL_NEF_NARY_UNION_H#define CGAL_NEF_NARY_UNION_H#include <list>CGAL_BEGIN_NAMESPACEtemplate<class Polyhedron>class Nary_union {  int inserted;  std::list<Polyhedron> queue;  typedef typename std::list<Polyhedron>::iterator pit;  Polyhedron empty; public:  Nary_union() : inserted(0) {}    void unite() {    pit i1(queue.begin()), i2(i1);    ++i2;    Polyhedron tmp(*i1 + *i2);    queue.pop_front();    queue.pop_front();    queue.push_front(tmp);  }  void add_polyhedron(const Polyhedron& P) {    queue.push_front(P);    ++inserted;    for(int i=2;(inserted%i) == 0; i*=2) {      unite();    }  }  Polyhedron get_union() {    while(queue.size() > 1)      unite();    return queue.front();  }};CGAL_END_NAMESPACE#endif // CGAL_NEF_NARY_UNION_H

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -