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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
LamerVCi
Сообщений: n/a
#1

Массив, вычисление суммы - C++

20.10.2012, 02:07. Просмотров 304. Ответов 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
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
#include <stdio.h>
#include <conio.h>
#include <iostream>
#include <iomanip>
using namespace std;
void main()
{
    float *a, sum, min, max, smin, pmin;
    int i, n, kpol, imin, imax, iimax, ipmin;
    printf ("Enter number n=");
    cin >>n;
    a=new float[n];
    kpol=0;
    imax=imin=iimax=ipmin=0;
    for (i=0 ; i<n ; i++) cin >>*(a+i);
        min=max=pmin=*a;
        sum=smin=0;
        for (i=1 ; i<n ; i++)
            if (*(a+i)>0 && *(a+i)>max)
                {
                    max=*(a+i);
                    imax=i;
            }
        for (i=1 ; i<n ; i++)
            if (*(a+i)>0 && *(a+i)<min)
                {
                    min=*(a+i);
                    imin=i;
            }
            for (i=1 ; (i<imax && i>imax) ; i++)
                if (*(a+i)>0 && *(a+i)=max) i=iimax;
            for (i=0 ; i<n ; i++)
                if (i>iimax && i<imax) sum+=*(a+i);
            for (i=0 ; (i<imin && i>imin) ; i++) 
                if (*(a+i)>0 && *(a+i)<pmin) ipmin=i;
                for (i=0 ; i<ipmin ; i++) smin+=*(a+i);
                    for (i=0 ; i<n ; i++)
                    if (*(a+i)>0)
                    {
                        *(a+kpol)=*(a+i);
                        kpol++;
                    }
                    if (kpol!=0)
                    {
                        printf ("massive polojitel'nogo elementa");
                        for (i=0 ; i<kpol ; i++)
                            cout <<setw(8)<<setprecision(9)<<*(a+i);
                        cout <<endl;
                    }
                    printf ("sum=%3.2f\n", sum);
                    printf ("smin=%3.2f\n", smin);
                        delete [] a;
                        getch();
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
20.10.2012, 02:07     Массив, вычисление суммы
Посмотрите здесь:

Вычисление суммы C++
C++ Вычисление суммы
C++ Вычисление суммы
вычисление суммы C++
C++ Вычисление суммы четных и суммы нечетных чисел в одномерном массиве
Вычисление суммы квадратов четных чисел и суммы кубов нечетных чисел C++
C++ Ввод элементов массива с клавиатуры, вычисление суммы по формуле, нахождение максимальной суммы
Вычисление суммы C++
C++ Вычисление суммы
C++ Вычисление суммы
Вычисление суммы C++
C++ Вычисление суммы

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
valeriikozlov
Эксперт C++
4663 / 2489 / 321
Регистрация: 18.08.2009
Сообщений: 4,550
20.10.2012, 09:24     Массив, вычисление суммы #2
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
#include <stdio.h>
#include <conio.h>
#include <iostream>
#include <iomanip>
using namespace std;
void main()
{
    float *a, sum, smin;
    int i, n, kpol, imin, imax, iimax, ipmin;
    printf ("Enter number n=");
    cin >>n;
    a=new float[n];
    kpol=0;
    imax=imin=iimax=ipmin=0;
    for (i=0 ; i<n ; i++)
    {
        cin >>*(a+i);
        if(*(a+i)==*(a+imax))
            iimax=i;
        if(*(a+i)>*(a+imax))
        {
            imax=iimax=i;
        }
        if(*(a+i)==*(a+imin))
        {
 
            ipmin=imin;
            imin=i;
        }
        if(*(a+i)<*(a+imin))
        {
            ipmin=imin=i;
        }
 
    }
    sum=smin=0;
    for(i=imax+1; i<iimax; i++)
        if(*(a+i)>0)
            sum+=*(a+i);
    if(ipmin!=imin)
        for(i=0; i<ipmin; i++)
            smin+=*(a+i);
    cout <<"sum= "<<fixed<<setprecision(2)<<sum<<endl;
    cout <<"smin= "<<fixed<<setprecision(2)<<smin<<endl;
    for (i=0 ; i<n ; i++)
        if (*(a+i)>0)
        {
            *(a+kpol)=*(a+i);
            kpol++;
        }
    if (kpol!=0)
    {
        cout<<"massive polojitel'nogo elementa"<<endl;
        for (i=0 ; i<kpol ; i++)
            cout <<setw(6)<<fixed<<setprecision(2)<<*(a+i);
        cout <<endl;
    }
    delete [] a;
    getch();
}
Yandex
Объявления
20.10.2012, 09:24     Массив, вычисление суммы
Ответ Создать тему
Опции темы

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