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

Подсчет подряд идущих отрицательных элементов - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Как исправить код с istream_iterator? http://www.cyberforum.ru/cpp-beginners/thread1068802.html
Как исправить этот код, чтобы ввод заканчивался при вводе слова quit? Можно ли сделать с итераторами или уже нужно в простом цикле ввод проверять? #include <iostream> #include <algorithm> #include <iterator> #include <vector> using namespace std; typedef istream_iterator< string > is;
C++ Найти максимальный элемент матрицы расположенный выше побочной диагонали и его местоположение 2d массив C++ Добавлено через 12 минут Дана матрица размером . Добавлено через 2 часа 25 минут Максимальный среди элементов расположенных выше побочной диагонали http://www.cyberforum.ru/cpp-beginners/thread1068798.html
Занулить элементы в матрице между min и max C++
сообственно нужно написать функцию которая будет занулять элементы между минимальным и максимальным ну я смог найти места минимального и максимального элемента но как занулить все между ними ? #include <iostream> #include <time.h> using namespace std; void RandMat(int **matrix, int n, int m) {
C++ Определить максимальный и минимальный элемент двумерного массива
Дан двумерный массив. Определить: а) Максимальное значение среди элементов третьего столбца массива; б) Минимальное значение среди элементов второй строки массива. Заранее огромное спасибо!
C++ Определить количество положительных и количество отрицательных элементов массива http://www.cyberforum.ru/cpp-beginners/thread1068793.html
Определить количество положительных и количество отрицательных элементов массива Заранее огромное спасибо!
C++ Определить порядковый номер автомобиля, имевшего максимальную из средних скоростей движения Известны длины участков пути (в км), которые проехали 25 легковых автомобилей, и время, затраченное каждым из них (в ч.). Определить порядковый номер автомобиля, имевшего максимальную из средних скоростей движения на участках. Заранее огромное спасибо! подробнее

Показать сообщение отдельно
outoftime
║XLR8║
509 / 431 / 33
Регистрация: 25.07.2009
Сообщений: 2,295
12.01.2014, 10:59
CHELOVEKPAUK,
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>
#include <iterator>
#include <string>
#include <type_traits>
 
template<typename _TypeIter>
size_t count(_TypeIter first, _TypeIter last)
{
    //static_assert(std::is_pointer<_TypeIter>::value,
    //              "Type iterator must be pointer type.");
    //static_assert(std::is_arithmetic<std::remove_pointer<_TypeIter>::type>::value,
    //              "Poited type must be arithmetic.");
 
    size_t res = 1, tmp = 0;
    while (first != last)
    {
        //typedef decltype(*first) _Type;
        *first++ < 0 ? ++tmp : tmp = 0;
        res = std::max(res, tmp);
    }
 
    return res < 2 ? 0 : res;
}
 
int main(int argc, char* argv[])
{
    //int a[] = {1,2,3,4,-1,-1,0,1,2,3,4,0};
    //std::vector<int> a = {1,2,3,4,-1,-1,0,1,2,3,4,0};
    std::vector<std::string> a = {"213", "123123", ""};
 
    std::cout << count(std::begin(a), std::end(a));
}
В целом - работает. Комменты это мои жалкие потуги делать проверку на наличие интерфейсов сравнения и приведения типов, но потом понял что все это и так делает компилятор, оставил чисто что-бы понять что я хотел еще прикрутить (:
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru