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

Найти сумму положительных элементов массива до максимального и заменить отрицательные элементы квадратами

09.10.2016, 15:47. Показов 1152. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
В одномерном массиве, состоящем из n вещественных элементов, вычислить:
1)сумму положительных элементов массива, расположенных до максимального
2)Заменить все отрицательные элементы массива их квадратами
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
09.10.2016, 15:47
Ответы с готовыми решениями:

Найти сумму положительных элементов массива Все отрицательные элементы заменить на 0
Нужна помощь с написанием программ C# Net Framework 4.7.2, VS 2017 желательно, но можно и другого года. 5. Заполнить массив В(3,4)...

Заполнить массив В(3,4) случайным образом. Найти сумму положительных элементов. Все отрицательные элементы заменить на 0
Мне нужно только Все отрицательные элементы заменить на 0. Мой код: private void button1_Click(object sender, EventArgs e) {...

Найти сумму положительных элементов массива, все отрицательные элементы удвоить
Помогите студенту! Дан массив а, найти сумму положительных элементов, все отрицательные элементы удвоить

3
Неэпический
 Аватар для Croessmah
18146 / 10730 / 2066
Регистрация: 27.09.2012
Сообщений: 27,029
Записей в блоге: 1
09.10.2016, 16:07
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
//g++  4.9.3
 
#include <iostream>
 
 
int main()
{    
    int arr[] = {6, 8, -4, 3, 9, 4, -5, 9, 5, 7};
    const std::size_t size = sizeof(arr)/sizeof(*arr);
    int gSum = 0;
    int max = arr[0];
    int lSum = max;
    for (std::size_t i = 1 ; i < size; ++i) {
        if( arr[i] > max ) { //До первого максимального. (arr[i] >= max) - до последнего максимального.
            gSum += lSum;
            lSum = max = arr[i];
        } else {
            lSum += arr[i];
        }
        if ( arr[i] < 0 ) {
            arr[i] *= arr[i];
        }
    }
    std::cout << "Sum: " << gSum << "\nResult: ";
    for (std::size_t i = 0; i < size; ++i) {
        std::cout << arr[i] << "; ";
    }
}
http://rextester.com/QOT4829

P.S. Только для положительных сделайте сами.
0
0 / 0 / 0
Регистрация: 04.06.2016
Сообщений: 5
09.10.2016, 16:12
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
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
#include <stdio.h> 
#include <conio.h> 
#include <windows.h> 
#include <cstdio>
#include <iostream>
#include <cstdio>
 
using namespace std;
 
void ReadMas(float *mas, int n) //считывание и вывод массива
{
    for (int i(0); i < n; i++)     //считывание массива
        scanf("%f", &mas[i]);
 
 
    printf("***  Массив Mas[%d]  ***\n", n); //вывод на экран
    for (int i(0); i < n; i++)
        printf("%5.1f ", mas[i]);
    printf("\n\n");
    return;
}
 
float Search(float *mas, int n)
{
    float sum = 0;
    float max = mas[0];
    int index = 0;
 
    for (int i(0); i < n; i++) //ищем максимальный элемент массива
        if (mas[i] >= max)
        {
            max = mas[i];
            index = i;
        }
 
    for (int j(0); j < index; j++) //ищем сумму положительных элементов до максимального элемента
        if (mas[j] > 0)
            sum += mas[j];
 
    return sum;
}
 
void Composition(float *mas, int n) //решение задачи
{
    for (int i(0); i < n; i++)
        if (mas[i] < 0)
        {
            mas[i] *= mas[i];
        }
}
 
 
 
//---------------------------------------------------------------------------
void main()
{
    setlocale(LC_ALL, "Russian");
    
    printf("\t******  Задача  *****\n\n");
 
    //------------------------объявление массива------------------------//
    int n;
    printf("Введите размерность массива -> ");
    scanf("%d", &n); //считываем размерность массива
 
    float *mas = new float[n];
 
    printf("Введите массив: ");
    ReadMas(mas, n);
 
    //-----------------------решение------------------------------//
 
    float ans1;
 
    ans1 = Search(mas, n);
 
    printf("Сумма положительных элементов массива Answer1 = %5.1f \n\n", ans1);
 
    float ans2;
 
    Composition(mas, n);
 
    printf("Все отрицательные элементы массива заменены их квадратами\n");
 
    for (int i(0); i < n; i++)
        printf("%5.1f ", mas[i]);
    printf("\n\n");
 
 
    //-----------------------освобождение памяти------------------------------//
 
    delete[] mas;
 
    printf("Press any key to continue\n\n");
 
    getch();
    return;
}
P.S. вещественные числа нужно вводить через запятую (5,8 и тд).
0
62 / 62 / 55
Регистрация: 18.10.2014
Сообщений: 190
09.10.2016, 16:12
C++
1
2
3
4
5
6
7
8
9
10
11
 for (std::size_t i = 1 ; i < size; ++i) {
        if( arr[i] > max ) { //До первого максимального. (arr[i] >= max) - до последнего максимального.
            gSum += lSum;
            lSum = max = arr[i];
        } else {
            lSum += arr[i];
        }
        if ( arr[i] < 0 ) { //А как же 1 элемент массива?Вдруг он меньше 0 цикл же от 1 начинается
            arr[i] *= arr[i];
        }
    }
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
09.10.2016, 16:12
Помогаю со студенческими работами здесь

Массив: Найти сумму S положительных элементов массива, все отрицательные элементы удвоить.
Здравствуйте, помогите пожалуйста написать программу для 13 варианта, буду очень признателен, и если можно объяснить какая строка за что...

В одномерном массиве заменить отрицательные элементы на сумму положительных элементов
Я написала программу, скомпилировала, показало Done.. Но когда начинаю вводить массив, программа закрывается.. Посмотрите пожалуйста. ...

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

Отрицательные элементы массива заменить их квадратами
Задать с клавиатуры массив из 10 отрицательных и положительных чисел. Разрядность вводимых числе &lt;3. Организовать проверку ввода....

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


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru