Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.83/6: Рейтинг темы: голосов - 6, средняя оценка - 4.83
0 / 0 / 0
Регистрация: 24.08.2020
Сообщений: 20

Определить сумму элементов одномерного массива между первым и последним отрицательным элементами

24.08.2020, 00:25. Показов 1292. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Задача №2
Напишите программу, которая определяет сумму элементов одномерного
массива между первым отрицательным и последним отрицательным значениями массива.
Также вывести эти значения на экран. Если в массиве только одно отрицательное значение
или их нет вообще, вывести соответствующие сообщения. Одномерный массив
инициализируется случайными значениями, диапазон которых пользователь вводит с
клавиатуры.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
24.08.2020, 00:25
Ответы с готовыми решениями:

Вычислить сумму элементов массива, расположенных между первым и последним отрицательным элементами
- сумму элементов массива, расположенных между первым и последним отрицательным элементами

Вычислить сумму элементов одномерного массива, расположенных между первым и последним ненулевыми элементами
подскажите, как вычислить сумму элементов одномерного массива, расположенных между первым и последним ненулевыми элементами.

Найти сумму элементов массива между последним отрицательным и предпоследним отрицательным элементами
Дан одномерный массив из 1000 элементов, состоящий из случайных целых чисел в диапазоне от -15 до 14. Найти сумму элементов участка...

8
653 / 466 / 183
Регистрация: 23.04.2019
Сообщений: 1,987
24.08.2020, 16:45
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
43
44
45
46
47
48
49
50
51
52
53
#include <iostream>
#include <random>
#include <clocale>
#include <vector>
#include <algorithm>
#include <numeric>
 
int main()
{
    setlocale(LC_ALL, "RUS");
 
    const size_t size = 10;
 
    std::cout << "Введите диапазон" << std::endl;
    
    std::cout << "\tМинимальное значение: ";
    int min;
    std::cin >> min;
 
    std::cout << "\tМаксимальное значение: ";
    int max;
    std::cin >> max;
 
    std::vector<int> arr(size);
    for (size_t i = 0; i < arr.size(); i++)
    {
        arr[i] = min + rand() % (max - min + 1);
        std::cout << arr[i] << ' ';
    }
    std::cout << std::endl;
    auto first = std::find_if(arr.begin(), arr.end(), [](const int& val) {return val < 0; });
 
    auto last = first;
 
    for (auto it = last; it < arr.end(); it++)
    {
        if (*it < 0)
        {
            last = it;
        }
    }
 
    if (first == last)
    {
        std::cout << "Слишком мало отрицательных значений";
        return 0;
    }
    else
    {
        std::cout << "Сумма элементов: " << std::accumulate(first + 1, last, 0) << std::endl;
        std::cout << "Первое значение: " << *first << "\t Последнее значение: " << *last << std::endl;
    }
}
1
 Аватар для mvngr
225 / 189 / 98
Регистрация: 15.04.2018
Сообщений: 718
24.08.2020, 17:15
AndryS1, пишу с калькулятора, а такой код подойдёт? Реверс итератор с обычным сможем норм сравнить без выстрелов в ногу?

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
auto first = std::find_if(arr.begin(), arr.end(), [](const int& val) {return val < 0; });
auto last = std::find_if(arr.rbegin(), arr.rend(), [](const int& val) {return val < 0; });
 
if (first == last)
    {
        std::cout << "Слишком мало отрицательных значений";
        return 0;
    }
    else
    {
        std::cout << "Сумма элементов: " << std::accumulate(first + 1, last, 0) << std::endl;
        std::cout << "Первое значение: " << *first << "\t Последнее значение: " << *last << std::endl;
    }
1
653 / 466 / 183
Регистрация: 23.04.2019
Сообщений: 1,987
24.08.2020, 17:21
Цитата Сообщение от mvngr Посмотреть сообщение
Реверс итератор с обычным сможем норм сравнить без выстрелов в ногу?
может как-то и сможет, но типы у них разные и в вашем варианте first == last даёт ошибку сравнения типов
я думал что можно как-то через них, но решил не парится
1
 Аватар для mvngr
225 / 189 / 98
Регистрация: 15.04.2018
Сообщений: 718
24.08.2020, 17:26
AndryS1, .base() у итераторов похоже смотреть надо
А так - у вас тут цикл не оптимальный, лучше же идти с конца

C++
1
for (auto it = last; it < arr.end(); it++)

Не по теме:

Бедный новичок, мучаете его std библиотеками, а ему лабу сдавать надо

1
653 / 466 / 183
Регистрация: 23.04.2019
Сообщений: 1,987
24.08.2020, 17:40
Цитата Сообщение от mvngr Посмотреть сообщение
Бедный новичок
когда люди формулируют так тему, им всё-равно на решение, "лижбыработало"

Добавлено через 1 минуту
mvngr, вот рабочее решение с реверс итераторами
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
43
44
45
#include <iostream>
#include <random>
#include <clocale>
#include <vector>
#include <algorithm>
#include <numeric>
 
int main()
{
    setlocale(LC_ALL, "RUS");
 
    const size_t size = 10;
 
    std::cout << "Введите диапазон" << std::endl;
 
    std::cout << "\tМинимальное значение: ";
    int min;
    std::cin >> min;
 
    std::cout << "\tМаксимальное значение: ";
    int max;
    std::cin >> max;
 
    std::vector<int> arr(size);
    for (size_t i = 0; i < arr.size(); i++)
    {
        arr[i] = min + rand() % (max - min + 1);
        std::cout << arr[i] << ' ';
    }
    std::cout << std::endl;
    auto first = std::find_if(arr.begin(), arr.end(), [](const int& val) {return val < 0; });
 
    auto last = std::find_if(arr.rbegin(), arr.rend(), [](const int& val) {return val < 0; });
 
    if (first == last.base())
    {
        std::cout << "Слишком мало отрицательных значений";
        return 0;
    }
    else
    {
        std::cout << "Сумма элементов: " << std::accumulate(first + 1, last.base() - 1, 0) << std::endl;
        std::cout << "Первое значение: " << *first << "\t Последнее значение: " << *last << std::endl;
    }
}
1
24.08.2020, 17:40

Не по теме:

AndryS1, лично у меня когда принимали лабу спрашивали как она работает, на выхлоп преподу было фиолетово

0
24.08.2020, 17:41

Не по теме:

mvngr, если ТС хочет понятное решение, пусть публикует свой вариант (хотя бы не рабочий), чтобы я отталкивался от него, а не от задания препода

0
 Аватар для mvngr
225 / 189 / 98
Регистрация: 15.04.2018
Сообщений: 718
24.08.2020, 17:44

Не по теме:

AndryS1, лично у меня когда принимали лабу спрашивали как она работает, на выхлоп преподу было фиолетово

Цитата Сообщение от AndryS1 Посмотреть сообщение
вот рабочее решение с реверс итераторами
Выглядит красиво, но тут чет не то

Code
1
2
3
4
5
Введите диапазон
        Минимальное значение: -1
        Максимальное значение: 50000 
17214 47011 25512 18332 19486 21366 6591 44505 42790 43838 
Для закрытия данного окна нажмите <ВВОД>...
Сообщенька "Слишком мало отрицательных значений" не вываливается

Добавлено через 2 минуты

Не по теме:

Цитата Сообщение от AndryS1 Посмотреть сообщение
пусть публикует свой вариант (хотя бы не рабочий)
полностью солидарен

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
24.08.2020, 17:44
Помогаю со студенческими работами здесь

Сумма элементов между первым и последним нулевыми элементами одномерного массива
Пожалуйста помогите. В одномерном массиве определить к-во элементов между первым и последним нулевыми элементами.

Найти сумму элементов массива, находящихся между первым и последним отрицательным элементом
В целочисленном массиве из 20 ти элементов, найти сумму элементов, находящихся между первым и последним отрицательным элементом.Массив...

сумму элементов массива, расположенных между первым и последним нулевыми элементами
В одномерном массиве, состоящем из n целых элементов, вычислить сумму элементов массива, расположенных между первым и последним нулевыми...

Сумму элементов массива, расположенных между первым и последним нулевыми элементами
Помогите пожалуйста! 1. Задан массив из N действительных чисел. Составьте программу для поиска в этом массиве: Сумму элементов массива,...

Найти сумму элементов между первым и последним положительными элементами массива
Полный вариант кода : #include &lt;stdio.h&gt; #include &lt;iostream&gt; #include &lt;conio.h&gt; #include &lt;windows&gt; #include &lt;stdlib&gt; ...


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru