60#pragma GCC system_header
70namespace __gnu_cxx _GLIBCXX_VISIBILITY(default)
72_GLIBCXX_BEGIN_NAMESPACE_VERSION
76 template<
typename _Tp,
typename _Integer,
typename _Mono
idOperation>
78 __power(_Tp __x, _Integer __n, _MonoidOperation __monoid_op)
81 return identity_element(__monoid_op);
84 while ((__n & 1) == 0)
87 __x = __monoid_op(__x, __x);
94 __x = __monoid_op(__x, __x);
96 __result = __monoid_op(__result, __x);
103 template<
typename _Tp,
typename _Integer>
105 __power(_Tp __x, _Integer __n)
115 template<
typename _Tp,
typename _Integer,
typename _Mono
idOperation>
117 power(_Tp __x, _Integer __n, _MonoidOperation __monoid_op)
118 {
return __power(__x, __n, __monoid_op); }
125 template<
typename _Tp,
typename _Integer>
128 {
return __power(__x, __n); }
130#if __cplusplus >= 201103L
139 template<
typename _ForwardIter,
typename _Tp>
141 iota(_ForwardIter __first, _ForwardIter __last, _Tp __value)
144 __glibcxx_function_requires(_Mutable_ForwardIteratorConcept<_ForwardIter>)
145 __glibcxx_function_requires(_ConvertibleConcept<_Tp,
148 while (__first != __last)
149 *__first++ = __value++;
153_GLIBCXX_END_NAMESPACE_VERSION
_Tp power(_Tp __x, _Integer __n, _MonoidOperation __monoid_op)
constexpr void iota(_ForwardIterator __first, _ForwardIterator __last, _Tp __value)
Create a range of sequentially increasing values.
GNU extensions for public use.
One of the math functors.
Traits class for iterators.
Parallel STL function calls corresponding to stl_numeric.h. The functions defined here mainly do case...