Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/6: Рейтинг темы: голосов - 6, средняя оценка - 5.00
 Аватар для Maxim09
1 / 1 / 4
Регистрация: 23.08.2015
Сообщений: 458

Одномерный динамический массив. Хочу разобраться (понять) код программы

02.07.2016, 10:52. Показов 1228. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Вот такая вот задача:
Написать прог-му которая для вещественного массива из (n) элементов определяет сумму элементов расположенный правее
последнего отрицательного элемента.
А вот непосредственно сама прога.

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
int n;                            //
cout<<"Vvedite kol-vo elementov"; //На этих строках определяется кол-во элементов(т.е. размерность как я понял) массива
cin>>n;                           //
int i,negativ;
float sum, *a=new float[n]; // А вот что делает эта строка если размерность мы уже присваиваем в ручную...?
cout<<"Vvedite element massiva";
for (i=0; i<n; i++) cin>>a[i]; // Тут тоже всё ясно
for (i=0; i<n; i++) 
if (a[i] < 0) negativ = i; // И тут тоже "вродебы" вычисляется последний отрицательный элемент массива.
for (sum=0, i=negativ+1; i<n;i++) // А вот эту строку я как-то не совсем понял, т.е. (i=negativ+1) что это ? negativ вроде не входит в основной массив ему же присваивается только последний негативный элемент массива. 
sum += a[i];
cou<<"Summa"<<sum<<endl;
system("pause");
Если можно то по проще и с комментариями желательно.
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
02.07.2016, 10:52
Ответы с готовыми решениями:

Можете прокомментировать этот код, хочу разобраться)!
#include &lt;iostream&gt; #include &lt;fstream&gt; using namespace std; int implic(int x, int y) { if (x &lt;= y) { return 1; } ...

Очень хочу понять код.Непонимаю его логику
Не могу понять, как они взаимодействуют... unit Unit1; interface uses Windows, Messages, SysUtils, Variants, Classes,...

Хочу разобраться.код внутри. JavaFX
Всем привет. В коде представленном ниже создаются круги которые можно передвигать: как на круг можно добавить текст, чтоб он...

3
Эксперт .NET
 Аватар для Даценд
5878 / 4755 / 2939
Регистрация: 20.04.2015
Сообщений: 8,361
02.07.2016, 11:25
Лучший ответ Сообщение было отмечено Maxim09 как решение

Решение

Цитата Сообщение от Maxim09 Посмотреть сообщение
C++
1
float sum, *a=new float[n]; // А вот что делает эта строка если размерность мы уже присваиваем в ручную...?
Поэтому эта строка и нужна, ибо размерность массива заранее (на этапе компиляции) неизвестна и в стеке память под него выделить не можно. Приходится место под массив выделять в ходе выполнения программы в динамической памяти (куче)
Цитата Сообщение от Maxim09 Посмотреть сообщение
C++
1
if (a[i] < 0) negativ = i; // И тут тоже "вродебы" вычисляется последний отрицательный элемент массива.
Не элемент, а его индекс
Цитата Сообщение от Maxim09 Посмотреть сообщение
C++
1
for (sum=0, i=negativ+1; i<n;i++) // А вот эту строку я как-то не совсем понял, т.е. (i=negativ+1) что это ? negativ вроде не входит в основной массив ему же присваивается только последний негативный элемент массива.
Здесь цикл с параметром i, начальное значение которого negativ+1, т.е. индекс элемента, следующего за последним отрицательным.
1
 Аватар для Maxim09
1 / 1 / 4
Регистрация: 23.08.2015
Сообщений: 458
02.07.2016, 11:48  [ТС]
Кажись понял спасибо.
0
1 / 1 / 0
Регистрация: 31.07.2013
Сообщений: 31
02.07.2016, 17:04
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
// hangman.cpp -- some string methods
#include <iostream>
#include <string>
#include <cstdlib>
#include <fstream>
#include <ctime>
#include <cctype>
#include <vector>
#include <conio.h>
#include <memory>
#include <algorithm>
#include <valarray>
 
 
using namespace std;
 
void readNumber(int n) { cin >> n; }
 
int main()
{
    setlocale(LC_ALL, "RUSSIAN");
 
    
    cout << "Введите размер массива: ";
    int sizeArray;
    cin >> sizeArray;
 
    vector<int> myArr(sizeArray);
    int negativeNumber;
 
    cout << "Введите " << sizeArray << " чисел через пробел: ";
    for (int a = 0; a < sizeArray; a++)
    {
        cin >> myArr[a];
    }
 
 
    for (int a = sizeArray - 1; a >= 0; a--) // поиск самого правого отрицательного числа
    {
        if (myArr[a] < 0)
        {
            negativeNumber = a;
            break;
        }
    }
 
    int sum = 0;
    for (int a = ++negativeNumber; a < sizeArray; a++)
    {
        sum += myArr[a];
    }
 
 
    cout << "Вы ввели:\n";
 
    for (int a : myArr)
        cout << a << " ";
 
    cout << "\nСумма чисел после самого правого отрицательного числа: " << sum << "\n";
 
 
    return _getch();
}
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
02.07.2016, 17:04
Помогаю со студенческими работами здесь

Хочу понять код для вывода цветного текста findstr /a
Нашел такой занимательный код для вывода цветного текста. Помогите расшифровать, что делается в каждой строке. Интуитивно понимаю в общем...

Парни, хочу понять, как делается древовидное меню (код не нужен).
Люди, возникла задача сделать древовидное меню на asp.net webforms &amp; sql server. Ну с таблицей для хранения немного понятно (использовать...

Динамический массив (разобраться в ошибке)
Вылазит вот такая ошибка, работаю с динамическим массивом первый раз но судя по всему где то вылез за массив, но не пойму где ...

Одномерный динамический массив
Не сортирует массив, и не выводит исходный. Не могу найти косяк #include &quot;stdafx.h&quot; #include&lt;iostream&gt; ...

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


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru