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

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

11.12.2013, 19:53. Показов 751. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Помогите, пожалуйста, оформить пункты задания в виде функций.
В одномерном массиве, состоящем из 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;
       }
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
11.12.2013, 19:53
Ответы с готовыми решениями:

Оформить программу в виде функций
Недавно столкнулся с такой вот задачей: Дана матрица размером M на N, нужно сформировать одномерный массив из максимальных элементов...

Оформить программу в виде функций
#include &quot;stdafx.h&quot; #include &lt;iostream&gt; using namespace std; int main(){ int size,i; cout&lt;&lt;&quot;Enter size: &quot;; ...

Оформить в виде функций программу
Всем привет! Помогите пожалуйста оформить задачу в виде функций. /*В одномерном массиве, состоящем из n вещественных элементов,...

2
Заблокирован
11.12.2013, 21:29
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;
}
0
0 / 0 / 0
Регистрация: 01.11.2013
Сообщений: 4
11.12.2013, 22:54  [ТС]
Скажите, а где здесь функции?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
11.12.2013, 22:54
Помогаю со студенческими работами здесь

Оформить простейшие задачи в виде функций
Ребят помогите пожалуйста с задачками для CodeBlocks. Реализовать задачи 1 и 2 в виде функций выполняемых условно-бесконечном цикле...

Оформить одномерный массив в виде функций
и снова я мучаюсь с функциями:wall: и кажется снова они получились вложенными:gscratch: 1.) вычислить номер максимального по...

Программу оформить в виде функций законченные последовательности действий
Нужно переделать программу под это задание: Программу оформить в виде функций законченные последовательности действий. Все необходимые...

Отыскать вычисления, которые целесообразно оформить в виде стандартных функций
5 задание помогите пожалуйста

Работа с файлами. Формирование, Печать, добавление и удаление элементов оформить в виде функций
Сформировать двоичный файл, распечатать его содержимое. Формирование, печать, добавление и удаление элементов оформить в виде функций....


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru