59#pragma GCC system_header
66namespace __gnu_cxx _GLIBCXX_VISIBILITY(default)
68_GLIBCXX_BEGIN_NAMESPACE_VERSION
72 template<
typename _Tp,
typename _Integer,
typename _Mono
idOperation>
74 __power(_Tp __x, _Integer __n, _MonoidOperation __monoid_op)
77 return identity_element(__monoid_op);
80 while ((__n & 1) == 0)
83 __x = __monoid_op(__x, __x);
90 __x = __monoid_op(__x, __x);
92 __result = __monoid_op(__result, __x);
99 template<
typename _Tp,
typename _Integer>
101 __power(_Tp __x, _Integer __n)
111 template<
typename _Tp,
typename _Integer,
typename _Mono
idOperation>
113 power(_Tp __x, _Integer __n, _MonoidOperation __monoid_op)
114 {
return __power(__x, __n, __monoid_op); }
121 template<
typename _Tp,
typename _Integer>
124 {
return __power(__x, __n); }
126#if __cplusplus >= 201103L
135 template<
typename _ForwardIter,
typename _Tp>
137 iota(_ForwardIter __first, _ForwardIter __last, _Tp __value)
140 __glibcxx_function_requires(_Mutable_ForwardIteratorConcept<_ForwardIter>)
141 __glibcxx_function_requires(_ConvertibleConcept<_Tp,
144 while (__first != __last)
145 *__first++ = __value++;
149_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.
Traits class for iterators.
One of the math functors.
Parallel STL function calls corresponding to stl_numeric.h. The functions defined here mainly do case...