_algobase.c

来自「stl的源码」· C语言 代码 · 共 484 行 · 第 1/2 页

C
484
字号
/* * * Copyright (c) 1994 * Hewlett-Packard Company * * Copyright (c) 1996,1997 * Silicon Graphics Computer Systems, Inc. * * Copyright (c) 1997 * Moscow Center for SPARC Technology * * Copyright (c) 1999 * Boris Fomitchev * * This material is provided "as is", with absolutely no warranty expressed * or implied. Any use is at your own risk. * * Permission to use or copy this software for any purpose is hereby granted * without fee, provided the above notices are retained on all copies. * Permission to modify the code and to distribute modified code is granted, * provided the above notices are retained, and a notice that the code was * modified is included with the above copyright notice. * */#ifndef _STLP_ALGOBASE_C#define _STLP_ALGOBASE_C#ifndef _STLP_INTERNAL_ALGOBASE_H#  include <stl/_algobase.h>#endif#ifndef _STLP_INTERNAL_FUNCTION_BASE_H#  include <stl/_function_base.h>#endif_STLP_BEGIN_NAMESPACEtemplate <class _InputIter1, class _InputIter2>bool lexicographical_compare(_InputIter1 __first1, _InputIter1 __last1,                             _InputIter2 __first2, _InputIter2 __last2) {  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first1, __last1))  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first2, __last2))  for ( ; __first1 != __last1 && __first2 != __last2        ; ++__first1, ++__first2) {    if (*__first1 < *__first2) {      _STLP_VERBOSE_ASSERT(!(*__first2 < *__first1), _StlMsg_INVALID_STRICT_WEAK_PREDICATE)      return true;    }    if (*__first2 < *__first1)      return false;  }  return __first1 == __last1 && __first2 != __last2;}template <class _InputIter1, class _InputIter2, class _Compare>bool lexicographical_compare(_InputIter1 __first1, _InputIter1 __last1,                             _InputIter2 __first2, _InputIter2 __last2,                             _Compare __comp) {  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first1, __last1))  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first2, __last2))  for ( ; __first1 != __last1 && __first2 != __last2        ; ++__first1, ++__first2) {    if (__comp(*__first1, *__first2)) {      _STLP_VERBOSE_ASSERT(!__comp(*__first2, *__first1),                           _StlMsg_INVALID_STRICT_WEAK_PREDICATE)      return true;    }    if (__comp(*__first2, *__first1))      return false;  }  return __first1 == __last1 && __first2 != __last2;}#if !defined (_STLP_NO_EXTENSIONS)_STLP_MOVE_TO_PRIV_NAMESPACEtemplate <class _InputIter1, class _InputIter2>int __lexicographical_compare_3way(_InputIter1 __first1, _InputIter1 __last1,                                   _InputIter2 __first2, _InputIter2 __last2) {  while (__first1 != __last1 && __first2 != __last2) {    if (*__first1 < *__first2) {      _STLP_VERBOSE_ASSERT(!(*__first2 < *__first1), _StlMsg_INVALID_STRICT_WEAK_PREDICATE)      return -1;    }    if (*__first2 < *__first1)      return 1;    ++__first1;    ++__first2;  }  if (__first2 == __last2) {    return !(__first1 == __last1);  }  else {    return -1;  }}_STLP_MOVE_TO_STD_NAMESPACEtemplate <class _InputIter1, class _InputIter2>int lexicographical_compare_3way(_InputIter1 __first1, _InputIter1 __last1,                                 _InputIter2 __first2, _InputIter2 __last2) {  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first1, __last1))  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first2, __last2))  return _STLP_PRIV __lexicographical_compare_3way(__first1, __last1, __first2, __last2);}#endif_STLP_MOVE_TO_PRIV_NAMESPACEtemplate <class _RandomAccessIter, class _Tp>_STLP_INLINE_LOOP _RandomAccessIter __find(_RandomAccessIter __first, _RandomAccessIter __last,                                           const _Tp& __val,                                           const random_access_iterator_tag &) {  _STLP_DIFFERENCE_TYPE(_RandomAccessIter) __trip_count = (__last - __first) >> 2;  for ( ; __trip_count > 0 ; --__trip_count) {    if (*__first == __val) return __first;    ++__first;    if (*__first == __val) return __first;    ++__first;    if (*__first == __val) return __first;    ++__first;    if (*__first == __val) return __first;    ++__first;  }  switch (__last - __first) {  case 3:    if (*__first == __val) return __first;    ++__first;  case 2:    if (*__first == __val) return __first;    ++__first;  case 1:    if (*__first == __val) return __first;    //++__first;  case 0:  default:    return __last;  }}inline char*__find(char* __first, char* __last, char __val, const random_access_iterator_tag &) {  void *res =  memchr(__first, __val, __last - __first);  return res != 0 ? __STATIC_CAST(char*, res) : __last;}inline const char*__find(const char* __first, const char* __last, char __val, const random_access_iterator_tag &) {  const void *res =  memchr(__first, __val, __last - __first);  return res != 0 ? __STATIC_CAST(const char*, res) : __last;}template <class _RandomAccessIter, class _Predicate>_STLP_INLINE_LOOP _RandomAccessIter __find_if(_RandomAccessIter __first, _RandomAccessIter __last,                                              _Predicate __pred,                                              const random_access_iterator_tag &) {  _STLP_DIFFERENCE_TYPE(_RandomAccessIter) __trip_count = (__last - __first) >> 2;  for ( ; __trip_count > 0 ; --__trip_count) {    if (__pred(*__first)) return __first;    ++__first;    if (__pred(*__first)) return __first;    ++__first;    if (__pred(*__first)) return __first;    ++__first;    if (__pred(*__first)) return __first;    ++__first;  }  switch(__last - __first) {  case 3:    if (__pred(*__first)) return __first;    ++__first;  case 2:    if (__pred(*__first)) return __first;    ++__first;  case 1:    if (__pred(*__first)) return __first;      //++__first;  case 0:  default:    return __last;  }}template <class _InputIter, class _Tp>_STLP_INLINE_LOOP _InputIter __find(_InputIter __first, _InputIter __last,                                    const _Tp& __val,                                    const input_iterator_tag &) {  while (__first != __last && !(*__first == __val)) ++__first;  return __first;}template <class _InputIter, class _Predicate>_STLP_INLINE_LOOP _InputIter __find_if(_InputIter __first, _InputIter __last,                                       _Predicate __pred,                                       const input_iterator_tag &) {  while (__first != __last && !__pred(*__first))    ++__first;  return __first;}_STLP_MOVE_TO_STD_NAMESPACEtemplate <class _InputIter, class _Predicate>_InputIter find_if(_InputIter __first, _InputIter __last,                   _Predicate __pred) {  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first, __last))  return _STLP_PRIV __find_if(__first, __last, __pred, _STLP_ITERATOR_CATEGORY(__first, _InputIter));}template <class _InputIter, class _Tp>_InputIter find(_InputIter __first, _InputIter __last, const _Tp& __val) {  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first, __last))  return _STLP_PRIV __find(__first, __last, __val, _STLP_ITERATOR_CATEGORY(__first, _InputIter));}template <class _ForwardIter1, class _ForwardIter2, class _BinaryPred>_ForwardIter1 search(_ForwardIter1 __first1, _ForwardIter1 __last1,                     _ForwardIter2 __first2, _ForwardIter2 __last2,                     _BinaryPred  __pred) {  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first1, __last1))  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first2, __last2))  // Test for empty ranges  if (__first1 == __last1 || __first2 == __last2)    return __first1;  // Test for a pattern of length 1.  _ForwardIter2 __p1(__first2);  if ( ++__p1 == __last2 ) {    while (__first1 != __last1 && !__pred(*__first1, *__first2)) {      ++__first1;    }

⌨️ 快捷键说明

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