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

📄 stl_numeric.h

📁 stl的源代码3.13版
💻 H
字号:
/* * * 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,1997 * 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. *//* NOTE: This is an internal header file, included by other STL headers. *   You should not attempt to use it directly. */#ifndef __SGI_STL_INTERNAL_NUMERIC_H#define __SGI_STL_INTERNAL_NUMERIC_H__STL_BEGIN_NAMESPACEtemplate <class _InputIterator, class _Tp>_Tp accumulate(_InputIterator __first, _InputIterator __last, _Tp __init){  for ( ; __first != __last; ++__first)    __init = __init + *__first;  return __init;}template <class _InputIterator, class _Tp, class _BinaryOperation>_Tp accumulate(_InputIterator __first, _InputIterator __last, _Tp __init,               _BinaryOperation __binary_op){  for ( ; __first != __last; ++__first)    __init = __binary_op(__init, *__first);  return __init;}template <class _InputIterator1, class _InputIterator2, class _Tp>_Tp inner_product(_InputIterator1 __first1, _InputIterator1 __last1,                  _InputIterator2 __first2, _Tp __init){  for ( ; __first1 != __last1; ++__first1, ++__first2)    __init = __init + (*__first1 * *__first2);  return __init;}template <class _InputIterator1, class _InputIterator2, class _Tp,          class _BinaryOperation1, class _BinaryOperation2>_Tp inner_product(_InputIterator1 __first1, _InputIterator1 __last1,                  _InputIterator2 __first2, _Tp __init,                   _BinaryOperation1 __binary_op1,                  _BinaryOperation2 __binary_op2){  for ( ; __first1 != __last1; ++__first1, ++__first2)    __init = __binary_op1(__init, __binary_op2(*__first1, *__first2));  return __init;}template <class _InputIterator, class _OutputIterator, class _Tp>_OutputIterator __partial_sum(_InputIterator __first, _InputIterator __last,              _OutputIterator __result, _Tp*){  _Tp __value = *__first;  while (++__first != __last) {    __value = __value + *__first;    *++__result = __value;  }  return ++__result;}template <class _InputIterator, class _OutputIterator>_OutputIterator partial_sum(_InputIterator __first, _InputIterator __last,            _OutputIterator __result){  if (__first == __last) return __result;  *__result = *__first;  return __partial_sum(__first, __last, __result, __VALUE_TYPE(__first));}template <class _InputIterator, class _OutputIterator, class _Tp,          class _BinaryOperation>_OutputIterator __partial_sum(_InputIterator __first, _InputIterator __last,               _OutputIterator __result, _Tp*, _BinaryOperation __binary_op){  _Tp __value = *__first;  while (++__first != __last) {    __value = __binary_op(__value, *__first);    *++__result = __value;  }  return ++__result;}template <class _InputIterator, class _OutputIterator, class _BinaryOperation>_OutputIterator partial_sum(_InputIterator __first, _InputIterator __last,            _OutputIterator __result, _BinaryOperation __binary_op){  if (__first == __last) return __result;  *__result = *__first;  return __partial_sum(__first, __last, __result, __VALUE_TYPE(__first),                        __binary_op);}template <class _InputIterator, class _OutputIterator, class _Tp>_OutputIterator __adjacent_difference(_InputIterator __first, _InputIterator __last,                      _OutputIterator __result, _Tp*){  _Tp __value = *__first;  while (++__first != __last) {    _Tp __tmp = *__first;    *++__result = __tmp - __value;    __value = __tmp;  }  return ++__result;}template <class _InputIterator, class _OutputIterator>_OutputIteratoradjacent_difference(_InputIterator __first,                    _InputIterator __last, _OutputIterator __result){  if (__first == __last) return __result;  *__result = *__first;  return __adjacent_difference(__first, __last, __result,                               __VALUE_TYPE(__first));}template <class _InputIterator, class _OutputIterator, class _Tp,           class _BinaryOperation>_OutputIterator__adjacent_difference(_InputIterator __first, _InputIterator __last,                       _OutputIterator __result, _Tp*,                      _BinaryOperation __binary_op) {  _Tp __value = *__first;  while (++__first != __last) {    _Tp __tmp = *__first;    *++__result = __binary_op(__tmp, __value);    __value = __tmp;  }  return ++__result;}template <class _InputIterator, class _OutputIterator, class _BinaryOperation>_OutputIterator adjacent_difference(_InputIterator __first, _InputIterator __last,                    _OutputIterator __result, _BinaryOperation __binary_op){  if (__first == __last) return __result;  *__result = *__first;  return __adjacent_difference(__first, __last, __result,                               __VALUE_TYPE(__first),                               __binary_op);}// Returns __x ** __n, where __n >= 0.  _Note that "multiplication"// is required to be associative, but not necessarily commutative. template <class _Tp, class _Integer, class _MonoidOperation>_Tp __power(_Tp __x, _Integer __n, _MonoidOperation __opr){  if (__n == 0)    return identity_element(__opr);  else {    while ((__n & 1) == 0) {      __n >>= 1;      __x = __opr(__x, __x);    }    _Tp __result = __x;    __n >>= 1;    while (__n != 0) {      __x = __opr(__x, __x);      if ((__n & 1) != 0)        __result = __opr(__result, __x);      __n >>= 1;    }    return __result;  }}template <class _Tp, class _Integer>inline _Tp __power(_Tp __x, _Integer __n){  return __power(__x, __n, multiplies<_Tp>());}// Alias for the internal name __power.  Note that power is an extension,// not part of the C++ standard.template <class _Tp, class _Integer, class _MonoidOperation>inline _Tp power(_Tp __x, _Integer __n, _MonoidOperation __opr){  return __power(__x, __n, __opr);}template <class _Tp, class _Integer>inline _Tp power(_Tp __x, _Integer __n){  return __power(__x, __n);}// iota is not part of the C++ standard.  It is an extension.template <class _ForwardIterator, class _Tp>void iota(_ForwardIterator __first, _ForwardIterator __last, _Tp __value){  while (__first != __last)    *__first++ = __value++;}__STL_END_NAMESPACE#endif /* __SGI_STL_INTERNAL_NUMERIC_H */// Local Variables:// mode:C++// End:

⌨️ 快捷键说明

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