Форум программистов, компьютерный форум, киберфорум
Наши страницы
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Показать сообщение отдельно
soon
2546 / 1311 / 177
Регистрация: 09.05.2011
Сообщений: 3,086
Записей в блоге: 1
29.12.2011, 12:40 0

Массивы.

29.12.2011, 12:40. Просмотров 321. Ответов 3
Метки (Все метки)

Ответ

Цитата Сообщение от testeron Посмотреть сообщение
Сумму элементов массива, расположенных после последнего элемента, равного нулю.
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
#include <vector>
#include <ctime>
#include <cstdlib>
#include <iostream>
#include <iterator>
#include <algorithm>
#include <numeric>
 
template <class Iterator, class T> Iterator rfind(Iterator end, Iterator begin, const T& num)
{
    Iterator e = --end;
    --begin;
    while(end != begin)
        if(*end-- == num)
            return end;
    return e;
}
 
int main()
{
    srand(time(nullptr));
    std::vector<int> v(10);
    std::generate(v.begin(), v.end(), [] { return rand() % 6; });
    std::copy(v.begin(), v.end(), std::ostream_iterator<int>(std::cout, " "));
    std::cout << std::endl;
    std::cout << std::accumulate(rfind(v.end(), v.begin(), 0) + 1, v.end(), 0) << std::endl;
    return 0;
}
Без C++0x
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
#include <vector>
#include <ctime>
#include <cstdlib>
#include <iostream>
#include <iterator>
#include <algorithm>
#include <numeric>
 
template <class Iterator, class T> Iterator rfind(Iterator end, Iterator begin, const T& num)
{
    Iterator e = --end;
    --begin;
    while(end != begin)
        if(*end-- == num)
            return end;
    return e;
}
 
template <class T> T gen() { return rand() % 6; }
 
int main()
{
    srand(time(NULL));
    std::vector<int> v(10);
    std::generate(v.begin(), v.end(), gen<int>);
    std::copy(v.begin(), v.end(), std::ostream_iterator<int>(std::cout, " "));
    std::cout << std::endl;
    std::cout << std::accumulate(rfind(v.end(), v.begin(), 0) + 1, v.end(), 0) << std::endl;
    return 0;
}


Вернуться к обсуждению:
Массивы.
0
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
29.12.2011, 12:40
Готовые ответы и решения:

Массивы. Циклические алгоритмы (Заполнить массивы случайными числами, лежащими в интервале 0 до 100)
Доброго дня, уважаемые форумчане, помогите пожалуйста решить задание....

Указатели и массивы. Индексация с помощью указателей. Передача массивов в функции. Динамические массивы (обработка матриц)
Для каждого элемента , bij, i= 1,...,n , j=1,...,n определяется свой...

Структуры, массивы, указатели, динамические массивы структур
Помогите с решением задачи (прикрепляю условие). Заранее спасибо.

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

Попадание точки. Массивы чисел. Массивы записей.
Всем привет. По языкам задали три контрольные на си. Я сам си не знаю, даже не...

3
Другие темы раздела
C++ Комментарии к программе http://www.cyberforum.ru/cpp-beginners/thread419796.html
Помогите, пожалуйста, написать комментарии к тексту программы. #include <iostream> #include <string> #include <sstream> std::string first(const std::string& string) { ...
C++ Найти минимальную суммарную длину n отрезков Всем привет. Пытаюсь решить задачу и ничего не выходит. Помогите решить. Условие: Пусть n красных и n синих точек на плоскости заданы своими координатами. Построить n отрезков с разноцветными... http://www.cyberforum.ru/cpp-beginners/thread419795.html
Решение задачи c++ C++
Написать программу вычисляющую значение функции y=√(9-x*x) на задонном орезке с заданным шагом H=0.25 помогите пожалйста а то я выйду не отестованным
C++ Сортировка методом пузырька
Написать программу, которая методом обмена («пузырька») сортирует по убыванию введенный с клавиатуры одномерный массив.
C++ Перевод из 2 в 10 сс компактнее http://www.cyberforum.ru/cpp-beginners/thread419783.html
Здравствуйте, вот у меня есть программа, которая переводит из 2 сс в 10 сс, учитывая и дробные числа... Но хочется узнать, можно ли написать прогу компактнее? И объясните, пожалуйста, как эта прога...
C++ Почему в адресе сайта http://qt.nokia.com/products/ присутствует слово nokia? Почему в адресе сайта http://qt.nokia.com/products/ присутствует слово nokia? подробнее
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2018, vBulletin Solutions, Inc.
Рейтинг@Mail.ru