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

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

28.10.2013, 15:59. Показов 1275. Ответов 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
13769 / 10962 / 6491
Регистрация: 18.12.2011
Сообщений: 29,237
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
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru