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

Сумма элементов одномерного массива

10.04.2011, 12:44. Показов 22167. Ответов 15
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Необходимо найти сумму элементов массива расположенных после минимального элемента.
Размер массива вводиться с клавиатуры. предусмотреть ввод данных как с клавиатуры так и с помощью функции rand(). числа могуть быть любые натуральные. спасибо всем, кто отликнется
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
10.04.2011, 12:44
Ответы с готовыми решениями:

Сумма элементов одномерного массива
Доброго времени суток! :) Будьте добры, помогите, пожалуйста. Ввести массив А(N). Найти сумму элементов массива, каждый элемент...

Сумма элементов произвольного одномерного массива
Помогите составить программу, которая находит сумму элементов произвольного одномерного массива

Рекурсия: сумма элементов одномерного массива
Написать рекурсивную функцию (+ саму программу), которая подсчитывает сумму элементов одномерного массива.

15
Фрилансер
Эксперт С++
 Аватар для Dekio
5845 / 1226 / 499
Регистрация: 23.11.2010
Сообщений: 3,373
Записей в блоге: 1
10.04.2011, 13: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
#include <iostream>
 
using namespace std;
 
int main()
{
    setlocale(LC_ALL,"Russian");
    int n, *p, sum=0;
    cout<<"Ââåäèòå ðàçìåð ìàññèâà\n";
    cin>>n;
    p=new int[n];
    bool label=false;
    cout<<"Ââåäèòå ýëåìåíòû ìàññèâà\n";
    for(int i=0; i<n; i++)
    {
            cin>>p[i];
            if(label)
            sum+=p[i];
            if(p[i]<0)
            label=true;
    }
    cout<<"Ñóììà ýëåìåíòîâ "<<sum<<endl; 
    delete [] p;
    system("pause");        
}
1
0 / 0 / 0
Регистрация: 10.04.2011
Сообщений: 41
10.04.2011, 13:11  [ТС]
к сожалению, а не понимаю языка С++. знаний не много. только С.
0
 Аватар для vitaska
101 / 101 / 15
Регистрация: 04.02.2010
Сообщений: 162
10.04.2011, 14:50
вот на С
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
#include <stdio.h>
#include <stdlib.h>
#include <locale.h>
#include <time.h>
#include <conio.h>
 
int main(void)
{
    setlocale( LC_ALL,"Russian" );
    srand( (unsigned ) time ( NULL ) );
    int * arr;
    int i, arrSize, indMin = 0, choice, min, sum = 0;
 
    printf("\n Введите размер массива: ");
    scanf("%d", &arrSize);
 
    arr = ( int * ) malloc( arrSize * sizeof( int ) );
 
    printf("\n Вариант ввода значений\n 1 - вручную, 2 - автоматически: ");
    scanf("%d", &choice);
 
    if( choice == 1 ){
        for ( i = 0; i < arrSize; i++ ) {
            printf( "\n array[ %d ] = ", i );
            scanf( "%d", &arr[ i ] );
        }
    }
    else {
        for ( i = 0; i < arrSize; i++ ) {
            arr[ i ] = rand() % 30;
        }
    }
 
    min = arr[ 0 ];
    printf("\nИсходный массив:\n");
    for ( i = 0; i < arrSize; i++ ) {
        printf ( "%d ", arr[ i ] );
         if( arr[ i ] < min ){
            indMin = i;
            min = arr[ i ];
        }
    }
 
    if( indMin == ( arrSize - 1 ) )
        printf( "\n\nМинимальный элемент последний в массиве! Сумма = 0\n" );
    else {
        printf( "\n\nМинимальный элемент в массиве arr[ %d ] = %d\n", indMin, sum );
        for ( i = indMin + 1; i < arrSize; i++ ) {
            sum += arr[ i ];
        }
        printf( "\n\nСумма элементов после минимального = %d\n", sum );
    }
 
    getch();
 
    return 0;
}
1
0 / 0 / 0
Регистрация: 10.04.2011
Сообщений: 41
10.04.2011, 18:25  [ТС]
Огромное спасибо vitaska. все работает идеально. благодарность не имеет границ

Добавлено через 9 минут
ну или почти идеально
Code
1
2
3
4
5
6
7
8
9
10
11
12
 Введите размер массива: 5
 
 Вариант ввода значений
 1 - вручную, 2 - автоматически: 2
 
Исходный массив:
6 27 24 10 10
 
Минимальный элемент в массиве arr[ 0 ] =0
 
 
Сумма элементов после минимального = 71
Добавлено через 9 минут
printf( "\n\nМинимальный элемент в массиве arr[ %d ] = %d\n", indMin, sum ); здесь в строке sum, заменил на min и все вышло.
Code
1
2
3
4
5
6
7
8
9
10
11
12
 Введите размер массива: 5
 
 Вариант ввода значений
 1 - вручную, 2 - автоматически: 2
 
Исходный массив:
13 7 17 10 25
 
Минимальный элемент в массиве arr[ 1 ] = 7
 
 
Сумма элементов после минимального = 52
спасибо еще раз. вот бы еще со всем этим разобраться что и как. с указателями у меня не очень

Добавлено через 28 минут
вроде в общем разобрался, но
arr = ( int * ) malloc( arrSize * sizeof( int ) ); вот в этой строке вообще не понятно что происходит.
0
 Аватар для Rexer
167 / 166 / 46
Регистрация: 10.10.2010
Сообщений: 725
10.04.2011, 18:29
Здесь выделяется динамически память под массив int размером arrSize,т.е сколько вы введи элементов таким размер и будет,если не выделять память динамически,то объявлять массив нужно так,mass[100],те не известно сколько будет у вас элементов и вы выделяете большое количество,чтобы все влезло,но так делать не очень целесообразно

Почитайте про динамическое выделение памяти и все поймете
1
12 / 12 / 2
Регистрация: 10.02.2011
Сообщений: 42
10.04.2011, 18:32
Цитата Сообщение от Den_i3_Kh Посмотреть сообщение
rr = ( int * ) malloc( arrSize * sizeof( int ) ); вот в этой строке вообще не понятно что происходит.
динамическое выделение памяти

Добавлено через 59 секунд
блин, запостили уже))
1
0 / 0 / 0
Регистрация: 10.04.2011
Сообщений: 41
10.04.2011, 19:54  [ТС]
ясно. спс

Добавлено через 1 час 19 минут
как это понять?
arr[ i ] = rand() % 30;
0
Фрилансер
Эксперт С++
 Аватар для Dekio
5845 / 1226 / 499
Регистрация: 23.11.2010
Сообщений: 3,373
Записей в блоге: 1
10.04.2011, 19:55
Den_i3_Kh, элементу аrr[i] присваиваем рандомное значение в диапазоне 0..30
0
Freelance
Эксперт С++
 Аватар для asics
2891 / 1826 / 356
Регистрация: 09.09.2010
Сообщений: 3,841
10.04.2011, 19:58
Цитата Сообщение от Dekio Посмотреть сообщение
в диапазоне 0..30
Точнее - [0;29]
0
Фрилансер
Эксперт С++
 Аватар для Dekio
5845 / 1226 / 499
Регистрация: 23.11.2010
Сообщений: 3,373
Записей в блоге: 1
10.04.2011, 20:02
asics, опечатался, в диапазоне 0..29
0
0 / 0 / 0
Регистрация: 10.04.2011
Сообщений: 41
10.04.2011, 20:49  [ТС]
почему именно от 0 до 29?
0
Фрилансер
Эксперт С++
 Аватар для Dekio
5845 / 1226 / 499
Регистрация: 23.11.2010
Сообщений: 3,373
Записей в блоге: 1
10.04.2011, 20:51
Den_i3_Kh, потому что счет идет с 0 до n-1. В данном случае n у нас 30
0
0 / 0 / 0
Регистрация: 10.04.2011
Сообщений: 41
10.04.2011, 21:56  [ТС]
ну так я же могу вводить любой диапазоне. например RAND_MAX. тогда в массив будут заполняться уже числа не от 0 до 30, а от 0 до RAND_MAX. так?
0
 Аватар для vitaska
101 / 101 / 15
Регистрация: 04.02.2010
Сообщений: 162
10.04.2011, 22:20
в общем случае формула для определения диапазона случайных чисел имеет вид
C++
1
rand()%(b-a+1)+a;
где
a - начало диапазона
b - конец диапазона
2
0 / 0 / 0
Регистрация: 10.04.2011
Сообщений: 41
10.04.2011, 23:12  [ТС]
-а потом +а. зачем это если оно не участвует в определении диапазона
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
10.04.2011, 23:12
Помогаю со студенческими работами здесь

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

Сумма одномерного массива
Создать функцию вычисления суммы элементов одномерного массива. Ввод элементов путем генерации случ чисел

Сумма элементов одномерного и многомерного массивов
Вот короче 2 массива, 1 одномерный 1 многомерный, многомерный вроде бы правильно считает сумму его чисел, а одномерный не понятно как...

Подсчитать количество элементов одномерного массива, которые превосходят среднее арифметическое всех элементов массива
Подсчитать количество элементов одномерного массива, которые превосходят среднее арифметическое всех элементов массива.

количество четных элементов одномерного массива до числа равному а, Определить количество нечетных элементов двумерного массива
1.Найти количество четных элементов одномерного массива до первого встреченного числа равного наперед заданному числу а. 2.Дан двумерный...


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

Или воспользуйтесь поиском по форуму:
16
Ответ Создать тему
Новые блоги и статьи
Философия технологии
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, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru