x
Yes
No
Do you want to visit DriveHQ English website?
首页
产品服务
价格
免费试用
下载客户端
关于我们
云文件服务
|
云备份服务
|
FTP服务
|
企业邮箱服务
|
网站托管
|
客户端软件
云文件服务
云备份服务
FTP服务
企业级邮箱服务
网站托管
客户端软件
algorithm.hpp - Hosted on DriveHQ Cloud IT Platform
返回上层目录
上传
下载
共享
发布
新建文件夹
新建文件
复制
剪切
删除
粘贴
评论
升级服务
路径: \\game3dprogramming\materials\GameFactory\GameFactoryDemo\references\boost_1_35_0\boost\detail\algorithm.hpp
旋转
特效
属性
历史版本
// (C) Copyright Jeremy Siek 2001. // Distributed under the Boost Software License, Version 1.0. (See accompany- // ing file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) /* * * Copyright (c) 1994 * Hewlett-Packard Company * * Permission to use, copy, modify, distribute and sell this software * and its documentation for any purpose is hereby granted without fee, * provided that the above copyright notice appear in all copies and * that both that copyright notice and this permission notice appear * in supporting documentation. Hewlett-Packard Company makes no * representations about the suitability of this software for any * purpose. It is provided "as is" without express or implied warranty. * * * Copyright (c) 1996 * Silicon Graphics Computer Systems, Inc. * * Permission to use, copy, modify, distribute and sell this software * and its documentation for any purpose is hereby granted without fee, * provided that the above copyright notice appear in all copies and * that both that copyright notice and this permission notice appear * in supporting documentation. Silicon Graphics makes no * representations about the suitability of this software for any * purpose. It is provided "as is" without express or implied warranty. */ #ifndef BOOST_ALGORITHM_HPP # define BOOST_ALGORITHM_HPP # include
// Algorithms on sequences // // The functions in this file have not yet gone through formal // review, and are subject to change. This is a work in progress. // They have been checked into the detail directory because // there are some graph algorithms that use these functions. #include
#include
namespace boost { template
Iter1 begin(const std::pair
& p) { return p.first; } template
Iter2 end(const std::pair
& p) { return p.second; } template
typename boost::detail::iterator_traits
::difference_type size(const std::pair
& p) { return std::distance(p.first, p.second); } #if 0 // These seem to interfere with the std::pair overloads :( template
typename Container::iterator begin(Container& c) { return c.begin(); } template
typename Container::const_iterator begin(const Container& c) { return c.begin(); } template
typename Container::iterator end(Container& c) { return c.end(); } template
typename Container::const_iterator end(const Container& c) { return c.end(); } template
typename Container::size_type size(const Container& c) { return c.size(); } #else template
typename std::vector
::iterator begin(std::vector
& c) { return c.begin(); } template
typename std::vector
::const_iterator begin(const std::vector
& c) { return c.begin(); } template
typename std::vector
::iterator end(std::vector
& c) { return c.end(); } template
typename std::vector
::const_iterator end(const std::vector
& c) { return c.end(); } template
typename std::vector
::size_type size(const std::vector
& c) { return c.size(); } #endif template
void iota(ForwardIterator first, ForwardIterator last, T value) { for (; first != last; ++first, ++value) *first = value; } template
void iota(Container& c, const T& value) { iota(begin(c), end(c), value); } // Also do version with 2nd container? template
OutIter copy(const Container& c, OutIter result) { return std::copy(begin(c), end(c), result); } template
bool equal(const Container1& c1, const Container2& c2) { if (size(c1) != size(c2)) return false; return std::equal(begin(c1), end(c1), begin(c2)); } template
void sort(Container& c) { std::sort(begin(c), end(c)); } template
void sort(Container& c, const Predicate& p) { std::sort(begin(c), end(c), p); } template
void stable_sort(Container& c) { std::stable_sort(begin(c), end(c)); } template
void stable_sort(Container& c, const Predicate& p) { std::stable_sort(begin(c), end(c), p); } template
bool any_if(InputIterator first, InputIterator last, Predicate p) { return std::find_if(first, last, p) != last; } template
bool any_if(const Container& c, Predicate p) { return any_if(begin(c), end(c), p); } template
bool container_contains(InputIterator first, InputIterator last, T value) { return std::find(first, last, value) != last; } template
bool container_contains(const Container& c, const T& value) { return container_contains(begin(c), end(c), value); } template
std::size_t count(const Container& c, const T& value) { return std::count(begin(c), end(c), value); } template
std::size_t count_if(const Container& c, Predicate p) { return std::count_if(begin(c), end(c), p); } template
bool is_sorted(ForwardIterator first, ForwardIterator last) { if (first == last) return true; ForwardIterator next = first; for (++next; next != last; first = next, ++next) { if (*next < *first) return false; } return true; } template
bool is_sorted(ForwardIterator first, ForwardIterator last, StrictWeakOrdering comp) { if (first == last) return true; ForwardIterator next = first; for (++next; next != last; first = next, ++next) { if (comp(*next, *first)) return false; } return true; } template
bool is_sorted(const Container& c) { return is_sorted(begin(c), end(c)); } template
bool is_sorted(const Container& c, StrictWeakOrdering comp) { return is_sorted(begin(c), end(c), comp); } } // namespace boost #endif // BOOST_ALGORITHM_HPP
algorithm.hpp
网页地址
文件地址
上一页 1/61
下一页
下载
( 6 KB )
Comments
Total ratings:
0
Average rating:
无评论
of 10
Would you like to comment?
Join now
, or
Logon
if you are already a member.