Форум программистов, компьютерный форум CyberForum.ru

Вычислить сумму элементов массива, расположенных после минимального элемента - C++

Восстановить пароль Регистрация
 
Альма
 Аватар для Альма
12 / 9 / 1
Регистрация: 25.11.2010
Сообщений: 353
Записей в блоге: 1
16.01.2014, 06:17     Вычислить сумму элементов массива, расположенных после минимального элемента #1
В одномерном массиве, состоящем из n вводимых с клавиатуры целых элементов, вычислить сумму
элементов массива, расположенных после минимального элемента.

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
//---------------------------------------------------------------------------
#include "stdafx.h"
#include <iostream>
#include <conio.h>
#include <math.h>
using namespace std;
#pragma hdrstop
//---------------------------------------------------------------------------
//#pragma argsused
int main(int argc, char* argv[])
{
float a[20], n, h, k, s;
int i;
cout << "\t Input N (<=20) ";
cin >> n;
cout << "\n\t Massiv A" << endl;
for (i = 0; i < n; i++) //ввод массива
{
cout << "\t a[ " << i + 1 << " ] = ";
cin >> a[i];
}
k = a[0];
for (i = 0; i <= n; i++)
{
if (a[i] < k) //если в массиве есть два одинаковых минимальных элемента то подсчет до 2 один мин элемента
{
k = a[i];
h = i+1;
}
}
s = 0;
for (i = h; i < n; i++)
{
s += a[i];
}
cout<<"\nSumma = "<< s;
_getch();
return 0;
}
Постоянно выводит сумму равной 0. Оцените свежим взглядом, где ошибка, пожалуйста!
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
16.01.2014, 06:17     Вычислить сумму элементов массива, расположенных после минимального элемента
Посмотрите здесь:

C++ Вычислить сумму элементов массива (состоящего из N элементов) расположенных после минимального элемента
В одномерном массиве вычислить количество отрицательных элементов и сумму модулей элементов, расположенных после минимального по модулю элемента C++
В одномерном целочисленном массиве вычислить сумму элементов, расположенных после минимального элемента C++
C++ Найти сумму модулей элементов массива, расположенных после минимального по модулю элемента
C++ Найти сумму модулей элементов массива, расположенных после минимального по модулю элемента
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
MrGluck
Ворчун
Эксперт С++
 Аватар для MrGluck
4919 / 2662 / 243
Регистрация: 29.11.2010
Сообщений: 7,399
16.01.2014, 06:45     Вычислить сумму элементов массива, расположенных после минимального элемента #2
Цитата Сообщение от Альма Посмотреть сообщение
for (i = 0; i <= n; i++)
индексация массивов идет от 0 до n-1.
Цитата Сообщение от Альма Посмотреть сообщение
cout << "\t Input N (<=20) ";
cin >> n;
А если пользователь введет 21 или 200?
Коль размер массива определяется во время выполнения - используйте динамическое выделение памяти.

В остальном вроде верно, не считая того, что код ужасно отформатирован и название у переменных неинформативные.
skident
23 / 23 / 2
Регистрация: 11.12.2011
Сообщений: 300
16.01.2014, 09:32     Вычислить сумму элементов массива, расположенных после минимального элемента #3
C++
1
2
3
4
5
if (a[i] < k) //если в массиве есть два одинаковых минимальных элемента то подсчет до 2 один мин элемента
{
k = a[i];
h = i+1;
}
Вот тут бы судя по вашему комменту, я бы сделал условие не меньше, а меньше равно, что повлечет за собой нахождение ПОСЛЕДНЕГО минимального элемента в массиве.

Тут лучше начинать цикл с единицы, так как нулевой элемент уже использовали.
C++
1
2
3
k = a[0];
for (i = 1/*0*/; i <= n; i++)
{
Тут бы вставить проверку
C++
1
2
3
4
5
6
7
cout << "\t Input N (<=20) ";
cin >> n;
if ( n > 20 )
{
    printf("Некорректный входной параметр!");
    return -1; //ну или в цикле сделать ввод, пока не получим нормальное значение от пользователя
}
А так вроде алгоритм сгодится и должен работать. Забейте для начала массив статическими данными и посмотрите как программа работает, если есть возможность запустите под дебагом и вообще думаю проблема найдется очень быстро
skident
23 / 23 / 2
Регистрация: 11.12.2011
Сообщений: 300
16.01.2014, 21:28     Вычислить сумму элементов массива, расположенных после минимального элемента #4
Вот написал код, который по сути делает то же, что и ваш. В нагрузку добавляю скрин с примером.

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
#include <iostream>
 
#define MAX_ARRAY_SIZE 20
 
using namespace std;
 
int main()
{
    int array[MAX_ARRAY_SIZE];
    int min;
    int size;
    int total = 0;
    int index = 0;
    
    cout << "Enter array size: ";
    cin >> size;
    
    if ( size > MAX_ARRAY_SIZE )
    {
        cout << "Incorrect size!!!" << endl;
        return -1;
    }
    
    cout << "Enter array elements one by one" << endl;
    for ( int i = 0; i < size; i++ )
    {
        cin >> array[i];
    }
    
    min = array[0];
    for ( int i = 1; i < size; i++ )
    {
        if ( array[i] <= min )
        {
            min = array[i];
            index = i + 1;
        }
    }
 
    for ( int i = index; i < size; i++ )
    {
        total += array[i];
    }
    
    cout << "Total result: " << total << endl;
    
    return 0;
}
Миниатюры
Вычислить сумму элементов массива, расположенных после минимального элемента  
Yandex
Объявления
16.01.2014, 21:28     Вычислить сумму элементов массива, расположенных после минимального элемента
Ответ Создать тему
Опции темы

Текущее время: 01:34. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru