Форум программистов, компьютерный форум CyberForum.ru

Массивы. - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Комментарии к программе http://www.cyberforum.ru/cpp-beginners/thread419796.html
Помогите, пожалуйста, написать комментарии к тексту программы. #include <iostream> #include <string> #include <sstream> std::string first(const std::string& string) { std::stringstream ss(string); std::string result; ss >> result;
C++ Найти минимальную суммарную длину n отрезков Всем привет. Пытаюсь решить задачу и ничего не выходит. Помогите решить. Условие: Пусть n красных и n синих точек на плоскости заданы своими координатами. Построить n отрезков с разноцветными концами, суммарная длина, которых минимальна (каждая точка является концом только одного отрезка). Плоскость я под себя определил такую: int a={{0,0,0...}...}; 3 красные точки red1,red2,red3 3... 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 сс, учитывая и дробные числа... Но хочется узнать, можно ли написать прогу компактнее? И объясните, пожалуйста, как эта прога переводит дробную часть #include <iostream> #include<string.h> using namespace std; int main() { string str; int i=0;
C++ Почему в адресе сайта http://qt.nokia.com/products/ присутствует слово nokia? Почему в адресе сайта http://qt.nokia.com/products/ присутствует слово nokia? подробнее

Показать сообщение отдельно
soon
 Аватар для soon
2536 / 1301 / 81
Регистрация: 09.05.2011
Сообщений: 3,086
Записей в блоге: 1
29.12.2011, 12:40     Массивы.
Цитата Сообщение от 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;
}
 
Текущее время: 03:29. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru