Карта сайта Kansoftware
НОВОСТИУСЛУГИРЕШЕНИЯКОНТАКТЫ
Разработка программного обеспечения

reverse_iter_fold

Boost , Chapter 1. Fusion 2.2 , Functions

Boost C++ Libraries

...one of the most highly regarded and expertly designed C++ library projects in the world. Herb Sutter and Andrei Alexandrescu, C++ Coding Standards

PrevUpHomeNext
Description

Для последовательности seq, начального состояния initial_state, и объекта двоичной функции или указателя функции f, reverse_iter_fold возвращает результат повторного применения двоичной f к результату предыдущего вызова f (inital_state, если это первый вызов) и итераторов на каждом элементе seq.

Synopsis
template<
    typename Sequence,
    typename State,
    typename F
    >
typename result_of::reverse_iter_fold<Sequence, State const, F>::type reverse_iter_fold(
    Sequence& seq, State const& initial_state, F f);
template<
    typename Sequence,
    typename State,
    typename F
    >
typename result_of::reverse_iter_fold<Sequence const, State const, F>::type reverse_iter_fold(
    Sequence const& seq, State const& initial_state, F f);
template<
    typename Sequence,
    typename State,
    typename F
    >
typename result_of::reverse_iter_fold<Sequence, State, F>::type reverse_iter_fold(
    Sequence& seq, State& initial_state, F f);
template<
    typename Sequence,
    typename State,
    typename F
    >
typename result_of::reverse_iter_fold<Sequence const, State, F>::type reverse_iter_fold(
    Sequence const& seq, State& initial_state, F f);

Table 1.43. Parameters

Параметр

Требование

Описание

seq

Модель Директивная последовательность

Аргументация операции

начальное состояние

Любой тип

Начальное состояние

f

f(it) с возвратным типом ::F(S,It)>::type для текущего состояния s типа it на элементе seq

Аргументация операции


Expression Semantics
reverse_iter_fold(seq, initial_state, f);

Тип возврата Любой тип

Семантика: Эквивалент f(...f(f(initial_state,itN),itN-1)...it1), где it1...itN являются последовательными итераторами на элементах seq.

Complexity

Линейный, точно результат_::размер<Последовательность>::значение приложения f.

Header
#include <boost/fusion/algorithm/iteration/reverse_iter_fold.hpp>
#include <boost/fusion/include/reverse_iter_fold.hpp>
Example
struct make_string
{
    typedef std::string result_type;
    template<typename T>
    std::string operator()(const std::string& str, const T& t) const
    {
        return str + boost::lexical_cast<std::string>(deref(t));
    }
};
...
const vector<int,int> vec(1,2);
assert(reverse_iter_fold(vec,std::string(""), make_string()) == "21");

PrevUpHomeNext

Статья reverse_iter_fold раздела Chapter 1. Fusion 2.2 Functions может быть полезна для разработчиков на c++ и boost.




Материалы статей собраны из открытых источников, владелец сайта не претендует на авторство. Там где авторство установить не удалось, материал подаётся без имени автора. В случае если Вы считаете, что Ваши права нарушены, пожалуйста, свяжитесь с владельцем сайта.



:: Главная :: Functions ::


реклама


©KANSoftWare (разработка программного обеспечения, создание программ, создание интерактивных сайтов), 2007
Top.Mail.Ru

Время компиляции файла: 2024-08-30 11:47:00
2025-05-19 18:02:18/0.0067288875579834/0