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

массив - C++

Восстановить пароль Регистрация
 
Malina1
0 / 0 / 0
Регистрация: 29.12.2011
Сообщений: 11
29.12.2011, 22:03     массив #1
Объявить массив целых чисел и заполнить его случайными значениями. Размер массива и диапазон значений его элементов заданы в Вашем варианте индивидуального задания. В индивидуальных заданиях указано также, какую обработку массива следует произвести.

Для всех вариантов задания следует иметь в виду следующее:

0 считается положительным числом, если в задании не оговорен какой-то другой его статус;
когда речь идет о какой-то последовательности чисел, имеется в виду последовательность с длиной, большей 1;
в тех случаях, когда задание требует выполнения каких-то вычислений, разрешается выполнять их с той точностью, которую обеспечивают операции целочисленной арифметики.

размерность массива 100
диапазон значений -100до 100

Найти ту непрерывную последовательность положительных чисел, сумма элементов в которой максимальная
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
29.12.2011, 22:03     массив
Посмотрите здесь:

C++ Задать массив вещественных чисел и вставить в исходный массив число
C++ Массив: Сформируйте массив C[n+m], состоящий из элементов массивов А и В, упорядоченный по возрастанию.
C++ Задан вектор X[20]. Положительные числа переписать в массив Y, а отрицательные в массив W
C++ задача записать в массив отрицательные элементы матрицы в массив и вывести их
Массив: Составить массив из двух исходных по заданному принципу заполнения C++
Массив: Переписать элементы одномерного массива A, попадающие в интервал [2, 6], в массив B. C++
Создать третий массив, в котором собрать элементы массива A, которые не включаются в массив B C++
Как в массив скопировать массив, который заполнен через указатели C++
Дан массив. Создать массив 2 из четных чисел первого массива C++
C++ Дан массив из 25 элементов. Сформировать из него новый массив, элементы которого кратны 5
C++ Описать класс Массив, найти массив, состоящий из элементов первого и второго массива

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
soon
 Аватар для soon
2536 / 1301 / 81
Регистрация: 09.05.2011
Сообщений: 3,086
Записей в блоге: 1
30.12.2011, 06:37     массив #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
34
35
36
#include <vector>
#include <iterator>
#include <algorithm>
#include <cstdlib>
#include <ctime>
#include <iostream>
#include <numeric>
 
int main()
{
    srand(time(nullptr));
    std::vector<int> v(100);
    std::generate(v.begin(), v.end(), [] { return rand() % 201 - 100; });
    std::copy(v.begin(), v.end(), std::ostream_iterator<int>(std::cout, " "));
    std::cout << std::endl;
    auto l = v.begin(), f = l, first = f, last = l;
    int sum = 0;
    while(true)
    {
        f = std::find_if(l, v.end(), [](int num) { return num >= 0; });
        l = std::find_if(f, v.end(), [](int num) { return num < 0; });
        if(f == v.end())
            break;
        if(f == l - 1)
            continue;
        auto s = std::accumulate(f, l, 0);
        if(s > sum)
        {
            sum = s;
            first = f;
            last = l;
        }
    }
    std::cout << sum << ' ' << first - v.begin() << " - "<< last - v.begin() - 1 <<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
31
32
33
34
35
36
37
38
39
40
41
42
#include <vector>
#include <iterator>
#include <algorithm>
#include <cstdlib>
#include <ctime>
#include <iostream>
#include <numeric>
 
template <class T> T gen() { return rand() % 201 - 100; }
 
template <class T> bool isPositiveOrEqZero(T num) { return num >= 0; }
 
template <class T> bool isNegative(T num) { return num < 0; }
 
int main()
{
    srand(time(NULL));
    std::vector<int> v(100);
    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::vector<int>::iterator l = v.begin(), f = l, first = f, last = l;
    int sum = 0;
    while(true)
    {
        f = std::find_if(l, v.end(), isPositiveOrEqZero<int>);
        l = std::find_if(f, v.end(), isNegative<int>);
        if(f == v.end())
            break;
        if(f == l - 1)
            continue;
        int s = std::accumulate(f, l, 0);
        if(s > sum)
        {
            sum = s;
            first = f;
            last = l;
        }
    }
    std::cout << sum << ' ' << first - v.begin() << " - "<< last - v.begin() - 1 <<std::endl;
    return 0;
}
Yandex
Объявления
30.12.2011, 06:37     массив
Ответ Создать тему
Опции темы

Текущее время: 03:45. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru