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

Массивы. Указатели. Обработка одномерных массивов

28.10.2013, 15:59. Показов 1331. Ответов 12
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Определите сумму элементов массива, расположенных до максимального.
Не вводить максимальный элемент, а находить его)
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
28.10.2013, 15:59
Ответы с готовыми решениями:

Массивы, указатели, обработка одномерных массивов
Вывести на экран все числа заданной последовательности, индексы которых есть степени тройки. Определить в заданной последовательности целых...

Указатели и массивы. Индексация с помощью указателей. Передача массивов в функции. Динамические массивы (обработка матриц)
Для каждого элемента , bij, i= 1,...,n , j=1,...,n определяется свой многоугольник местонахождением соответствующего элемента aij (см....

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

12
 Аватар для egor2116
584 / 387 / 216
Регистрация: 20.01.2013
Сообщений: 1,169
28.10.2013, 16:07
Как то так наверное

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
const size_t SIZE=10;
int array[SIZE]={1,2,3,4,5,6,10,7,8,9};
int max=0;
int sum=0;
 
for(int i=0;i<SIZE;++i)
   if(array[i]>max)
       max=array[i];
 
int i=0;
while(array[i]!=max && i<SIZE)
{
    sum+=array[i]; ++i;
}
0
1 / 1 / 0
Регистрация: 08.10.2013
Сообщений: 155
28.10.2013, 16:16  [ТС]
Цитата Сообщение от egor2116 Посмотреть сообщение
Как то так наверное

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
const size_t SIZE=10;
int array[SIZE]={1,2,3,4,5,6,10,7,8,9};
int max=0;
int sum=0;
 
for(int i=0;i<SIZE;++i)
   if(array[i]>max)
       max=array[i];
 
int i=0;
while(array[i]!=max && i<SIZE)
{
    sum+=array[i]; ++i;
}
в первом случаи вы проверяете все числа до максимального, а во втором на сумму?
0
 Аватар для egor2116
584 / 387 / 216
Регистрация: 20.01.2013
Сообщений: 1,169
28.10.2013, 16:20
Находим максимальное до которого будем суммировать
C++
1
2
3
for(int i=0;i<SIZE;++i)
  if(array[i]>max)
 max=array[i]; // переменная max содержит максимальное значение массива
Суммируем ...
C++
1
2
3
4
5
int i=0;
while(array[i]!=max && i<SIZE) // до максимального просматриваем массив
{
    sum+=array[i]; ++i; //суммируем все значение до максимального в переменную sum
}
0
1 / 1 / 0
Регистрация: 08.10.2013
Сообщений: 155
28.10.2013, 16:23  [ТС]
когда я его выполняю, то пишет "нажмите любую клавишу"
по идеи должно же что-то произойти? или нет?
0
 Аватар для egor2116
584 / 387 / 216
Регистрация: 20.01.2013
Сообщений: 1,169
28.10.2013, 16:25
хах

А что нужно что бы произошло?
Если вывести на экран то допишите строку
C++
1
cout<<"Сумма элементов массива до максимального ="<<max<<endl;
1
1 / 1 / 0
Регистрация: 08.10.2013
Сообщений: 155
28.10.2013, 16:30  [ТС]
не хочу показаться тупым, но появляются какие-то иероглифы и число 10)

Добавлено через 1 минуту
прошу прощения, не то посмотрел))
спасибо за помощь!!!!)))
0
 Аватар для Extrim88
51 / 51 / 21
Регистрация: 08.02.2013
Сообщений: 189
28.10.2013, 16:32
Универсальнее через динамический массив делать. Пользователь сможет самостоятельно выбрать размер массива. И далее заполнять его случайными числами в диапазоне например -100 - 100. Можно также написать какую-нибудь функцию, которая принимает в качестве параметров этот массив и его размер и возвращает индекс максимального элемента.
0
1 / 1 / 0
Регистрация: 08.10.2013
Сообщений: 155
28.10.2013, 16:33  [ТС]
Цитата Сообщение от Extrim88 Посмотреть сообщение
Универсальнее через динамический массив делать. Пользователь сможет самостоятельно выбрать размер массива. И далее заполнять его случайными числами в диапазоне например -100 - 100. Можно также написать какую-нибудь функцию, которая принимает в качестве параметров этот массив и его размер и возвращает индекс максимального элемента.
динамический массив - пример можно??
0
 Аватар для egor2116
584 / 387 / 216
Регистрация: 20.01.2013
Сообщений: 1,169
28.10.2013, 16:35
Вместо русских букв напишите латинскими

и пардон не cout<< max , а надо sum

приведу весь код

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
#include <iostream>
 
using namespace std;
 
int main(){
 
const size_t SIZE=10;
int array[SIZE]={1,2,3,4,5,6,10,7,8,9};
int max=0;
int sum=0;
 
for(int i=0;i<SIZE;++i)
   if(array[i]>max)
       max=array[i];
 
int i=0;
while(array[i]!=max && i<SIZE)
{
    sum+=array[i]; ++i;
}
cout<<"Summa elementov do maximalnogo ="<<sum<<endl;
}
Добавлено через 1 минуту
Универсальнее через динамический массив делать. Пользователь сможет самостоятельно выбрать размер массива.
А через статический нельзя ? Да неужели ))
И расскажите в чем универсальность. Поведайте тайну.
0
 Аватар для Extrim88
51 / 51 / 21
Регистрация: 08.02.2013
Сообщений: 189
28.10.2013, 16:52
Ну, например.

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
int main()
{
int size; //здесь будем хранить размер динамического массива
 
...
cout << "Ввести размер массива: ";
cin >> size;
 
int* p_array = new int[size]; 
/*выделяем достаточное кол-во памяти для массива, 
возвращаем адрес этого блока памяти*/
 
...
//Далее используем указатель p_array как имя динамического массива
...
//Не забудем освободить блок памяти выделенный под массив
delete [] p_array;
return 0;
}
Добавлено через 11 минут
[quote="egor2116;5249277"]А через статический нельзя ? Да неужели ))
И расскажите в чем универсальность. Поведайте тайну.[/quo

Ну почему же нельзя, вполне можно. Просто пользы от такого массива будет меньше, да и память в большинстве случаев расходуется не эффективно. Про статическое и динамическое связывание что-нибудь слышали?

Если вы жестко закодировали массив int array[Size] = {1, 2, 3, 4};
память для него выделяется раз и навсегда - во время компиляции, будет ли такой массив востребован в программе или нет, программе уже неинтересно.

При использовании же динамического массива, ситуация гораздо интересней, поскольку массив создается во время выполнения программы. Это позволяет более эффективно использовать память.
0
 Аватар для egor2116
584 / 387 / 216
Регистрация: 20.01.2013
Сообщений: 1,169
29.10.2013, 10:00
Это позволяет более эффективно использовать память.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
int main()
{
int size; //здесь будем хранить размер динамического массива
 
...
cout << "Ввести размер массива: ";
cin >> size;
 
int p_array[size];
/*выделяем достаточное кол-во памяти для массива, 
возвращаем адрес этого блока памяти*/
 
...
//Далее используем указатель p_array как имя динамического массива
...
 
return 0;
}
В условии задачи кажется не было про жесткое условие использование динамического массива. И ваша универсальность в данном элементарном примере просто смешна.
0
Модератор
Эксперт С++
 Аватар для zss
13773 / 10966 / 6491
Регистрация: 18.12.2011
Сообщений: 29,245
29.10.2013, 10:18
Кстати, по поводу экономии памяти.
Как Вы считаете, на что больше затратится памяти,
на
C++
1
char a[2];
или
C++
1
char *a=new char[2];
?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
29.10.2013, 10:18
Помогаю со студенческими работами здесь

Обработка одномерных массивов. Сортировка массивов
Здравствуйте, помогите пожалуйста решить задачу легким способом. В одномерном массиве, состоящем из n вещественных элементов, вычислить: ...

Обработка одномерных массивов
При заданных XT,YT, абциссах X1,X2,..,Xn и ординатах Y1,Y2,..,Yn n точек плоскости XOY определить,в каком числе случаев расстояние...

Обработка одномерных массивов С++
Написать программу решения задачи, используя оператор цикла FOR. Значения элементов массива ввести с клавиатуры или задать с помощью...

Обработка одномерных массивов С++
Написать программу решения задачи, используя оператор цикла FOR. Значения элементов массива ввести с клавиатуры или задать с помощью...

Обработка одномерных массивов
1. a) Одномерный массив из 5 элементов целого типа в диапазоне ; b) Дополнить исходный массив, начиная с третьего номера, пятью...


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

Или воспользуйтесь поиском по форуму:
13
Ответ Создать тему
Новые блоги и статьи
Оттенки серого
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