Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.91/11: Рейтинг темы: голосов - 11, средняя оценка - 4.91
8 / 8 / 1
Регистрация: 11.02.2013
Сообщений: 69
1

алгоритм accumulate

01.08.2013, 17:34. Просмотров 2128. Ответов 5
Метки нет (Все метки)

Допустим у меня есть вектор.Мне нужно подсчитать выборочно в нем сумму элементов.Я использую функциональный класс через алгоритм accumulate.А если мне нужно еще как-то подсчитать выборочно сумму элементов,мне нужно создать другой функциональный класс или можно каким-то образом использовать один?
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
01.08.2013, 17:34
Ответы с готовыми решениями:

accumulate if?
Какой алгоритм способен найти сумму элементов, удовлетворяющих какому-либо условию?

Ошибка с типами в STL accumulate
map<char, map<char, int>> Msucc; // заполнение Msucc map<char, int> strSum; for(...

Заполнить vector алгоритмом accumulate
В книге Скотта Майерса "Эффиктивный STL" рекомендовалось использовать алгоритмы вместо циклов. Из...

std::accumulate по столбцах двумерного массива
Есть массив: const int n = 10; int v; Как найти сумму элементов его столбца используя STL?

5
193 / 173 / 30
Регистрация: 10.07.2012
Сообщений: 799
01.08.2013, 20:20 2
Цитата Сообщение от Marina_P Посмотреть сообщение
Мне нужно подсчитать выборочно в нем сумму элементов
значения вектора изменяются? много ли подсчетов нужно выполнить? что значит "выборочно"?
0
8 / 8 / 1
Регистрация: 11.02.2013
Сообщений: 69
01.08.2013, 20:31  [ТС] 3
Значения не меняются.Допустим одна сумма 1*a[0]+2*a[1]+4*a[2]+8*a[3],а другая 1*a[0]-2*a[1]-4*a[2]-8*a[3].Меня интересует вопрос можно ли сделать два оператора в одном функциональном классе.
0
What a waste!
1576 / 1277 / 171
Регистрация: 21.04.2012
Сообщений: 2,677
01.08.2013, 20:38 4
Цитата Сообщение от Marina_P Посмотреть сообщение
Меня интересует вопрос можно ли сделать два оператора в одном функциональном классе.
Два оператора - нет. Но можно конструировать объект этого класса с разными параметрами, от которых будет зависеть, что делает operator ().
1
8 / 8 / 1
Регистрация: 11.02.2013
Сообщений: 69
01.08.2013, 21:19  [ТС] 5
В операторе сделать что-то типа switch?И выбирать тот метод,который мне нужен?
0
What a waste!
1576 / 1277 / 171
Регистрация: 21.04.2012
Сообщений: 2,677
01.08.2013, 21:41 6
Цитата Сообщение от Marina_P Посмотреть сообщение
В операторе сделать что-то типа switch?И выбирать тот метод,который мне нужен?
Если охота сделать switch, то лучше написать 2 разных класса. Я имел в виду что-нибудь вроде такого:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
#include <iostream>
#include <algorithm>
 
 
struct functor {
 
   functor(int const initial, int const multiplier)
         : initial(initial)
         , multiplier(multiplier)
         {}
 
   int operator ()(int const init, int const element) {
      int const ret = init + initial * element;
      initial *= multiplier;
      return ret;
   }
 
private:
   int initial;
   int const multiplier;
};
 
 
int main() {
   std::size_t const size = 4;
   int const array[size] = {1, 2, 3, 4};
 
   // 1*array[0] + 2*array[1] + 4*array[2] + 8*array[3]
   std::cout << std::accumulate(array, array + size, 0, functor(1, 2)) << std::endl;
 
   // -1*array[0] - 5*array[1] - 25*array[3] - 125*array[3]
   std::cout << std::accumulate(array, array + size, 0, functor(-1, 5)) << std::endl;
}
1
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
01.08.2013, 21:41

Заказываю контрольные, курсовые, дипломные и любые другие студенческие работы здесь.

Применить accumulate к vector<pair<int, int>>
Привет. Как можно применить accumulate к vector&lt;pair&lt;int, int&gt;&gt;?

Нужен алгоритм поиска пути в этом лабиринте (будь то волновой алгоритм или алгоритм правой/левой руки )
#include &quot;stdafx.h&quot; #include &lt;iostream&gt; #include &lt;conio.h&gt; using namespace std; void lab...

Волновой алгоритм поиска (Алгоритм A* / Алгоритм А стар)
Хочу разработать алгоритм для решения головоломки с подвижными дисками (перестановочная...

Создать процедуру accumulate
Как написать процедуру accumulate(+List,+Op,–Result), решающая след задачу? - accumulate(,'+',X)....


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2020, vBulletin Solutions, Inc.