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

📄 object_index.h

📁 很多二维 三维几何计算算法 C++ 类库
💻 H
字号:
// Copyright (c) 1997-2000  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: svn+ssh://scm.gforge.inria.fr/svn/cgal/branches/CGAL-3.3-branch/Nef_2/include/CGAL/Nef_2/Object_index.h $// $Id: Object_index.h 28567 2006-02-16 14:30:13Z lsaboret $// //// Author(s)     : Michael Seel <seel@mpi-sb.mpg.de>#ifndef OBJECT_INDEX_H#define OBJECT_INDEX_H#include <CGAL/basic.h>#include <CGAL/Unique_hash_map.h>#include <string>#include <sstream>CGAL_BEGIN_NAMESPACEtemplate <typename I>class Object_index {  char _prefix;  CGAL::Unique_hash_map<I,int> _index;public:  Object_index() : _prefix('\0'), _index(-1) {}  Object_index(I first, I beyond, char c=' ') : _prefix(c), _index(-1)  { for(int i=0 ; first!=beyond; ++i,++first) _index[first]=i; }  int operator[](const I& it) const { return _index[it]; }   int& operator[](const I& it) { return _index[it]; }   void index(I first, I beyond, char c=' ')  { _prefix=c;    for(int i=0 ; first!=beyond; ++i,++first) _index[first]=i;  }  std::string operator()(const I& it, bool verbose=true) const  { if (verbose && _index[it]==-1) return "nil";    if (verbose && _index[it]==-2) return "end";    std::ostringstream os;     if (verbose) os << _prefix;    os << _index[it];        return os.str();   }};CGAL_END_NAMESPACE#endif //OBJECT_INDEX_H

⌨️ 快捷键说明

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