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

Оформить в виде функций - C++

Восстановить пароль Регистрация
 
Yana333
0 / 0 / 0
Регистрация: 01.11.2013
Сообщений: 4
11.12.2013, 19:53     Оформить в виде функций #1
Помогите, пожалуйста, оформить пункты задания в виде функций.
В одномерном массиве, состоящем из n вещественных элементов, вычислить:
1) максимальный по модулю элемент массива;
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
#include <stdio.h>
#include <math.h>
#include <iostream>
using namespace std;
int main()
{       
    setlocale ( LC_ALL, "Russian" );
    const int n=10;
    int i, maxi, j;
    double a[n];
    cout<<"Введите 10 чисел:\n";
    for (i=0; i<n; ++i)
        cin>>a[i];
    for ( i = 0; i < n; ++i )
    cout<<"\n a["<<i<<"]="<<a[i];
    double max, sum, tmp;
        
/* Находим максимальный по модулю элемент массива */
        maxi = 0;
        max = fabs(a[maxi]);
        for ( i = 1; i < n; ++i ){
                if ( max < fabs(a[i]) ){
                        maxi = i;
                        max = fabs(a[maxi]);}
        }
        printf("\nМаксимальный элемент по модулю:\n[%d] = %.1f\t%.1f\n", maxi, a[maxi], max); 
        
        /* Находим сумму элементов массива расположенных между 1-м и 2-м положительными элементами*/
        i = 0;
        sum = 0.0;
        while ( a[i] < 0  && i < n )
                ++i;
        if ( i == n ){
                printf("\nВ массиве нет положительных элементов!\n");
                goto THREE;
        }
        ++i; 
        while ( a[i] < 0 && i < n )
                sum += a[i++];
        if ( i == n ){
                printf("\nВ массиве только один положительный элемент!\n");
                goto THREE;
        }
        printf("\nСумма между 1-м и 2-м положительными элементами%.1f\n", sum);
        
        THREE:
        for ( j = n- 1; j >=0 && a[j] == 0.0; --j );
        if ( j < 0 ){
                printf("\nВсе элементы в массиве нулевые\n");
                return 0;
       }
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
11.12.2013, 19:53     Оформить в виде функций
Посмотрите здесь:

Оформить программу в виде функций C++
Оформить одномерный массив в виде функций C++
C++ Оформить в виде отдельных функций введения, просмотр и определение количества чисел масива
Работа с файлами. Формирование, Печать, добавление и удаление элементов оформить в виде функций C++
C++ Оформить программу в виде функций
C++ Оформить в виде функций программу
C++ Оформить программу в виде функций обработки массивов (ввод, заполнение, вывод, упорядочение и т.п.)
Оформить простейшие задачи в виде функций C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
ТОрчОК
Заблокирован
11.12.2013, 21:29     Оформить в виде функций #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
#include <stdio.h>
#include <math.h>
#include <iostream>
using namespace std;
int main()
{       
    setlocale ( LC_ALL, "Russian" );
    const int n=10;
    int i, maxi, j;
    double a[n];
    cout<<"Введите 10 чисел:\n";
    for (i=0; i<n; ++i)
        cin>>a[i];
    for ( i = 0; i < n; ++i )
    cout<<"\n a["<<i<<"]="<<a[i];
    double max, sum, tmp;
        
/* Находим максимальный по модулю элемент массива */
        maxi = 0;
        max = fabs(a[maxi]);
        for ( i = 1; i < n; ++i ){
                if ( max < fabs(a[i]) ){
                        maxi = i;
                        max = fabs(a[maxi]);}
        }
        printf("\nМаксимальный элемент по модулю:\n[%d] = %.1f\t%.1f\n", maxi, a[maxi], max); 
        
        /* Находим сумму элементов массива расположенных между 1-м и 2-м положительными элементами*/
        i = 0;
        sum = 0.0;
        while(a[i] < 0 & i < n)
            i++;
        if(i == n)
            printf("\nНет положительных элементов\n");
        else
        {
            while(a[++i] < 0 & i < n)
                sum += a[i];
            printf("%.1f",sum);
        }
        if(a[i] < 0 & i == n)
            printf("\nНет крайнего правого положительного элемента\n");
 
        return 0;
}
Yana333
0 / 0 / 0
Регистрация: 01.11.2013
Сообщений: 4
11.12.2013, 22:54  [ТС]     Оформить в виде функций #3
Скажите, а где здесь функции?
Yandex
Объявления
11.12.2013, 22:54     Оформить в виде функций
Ответ Создать тему
Опции темы

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