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

Найти произведение элементов массива, расположенных между максимальным по модулю и минимальным по модулю элементами - C++

Восстановить пароль Регистрация
 
filimoncc
1 / 1 / 1
Регистрация: 02.12.2013
Сообщений: 101
18.12.2013, 15:53     Найти произведение элементов массива, расположенных между максимальным по модулю и минимальным по модулю элементами #1
Дан одномерный массив, состоящий из N вещественных элементов. Найти произведение элементов массива, расположенных между максимальным по модулю и минимальным по модулю элементами.
Формат входных данных
В первой строке входного файла содержится число N (1\le N\le 100). Во второй строке даны N вещественных чисел через пробел. Гарантируется, что среди них только одно максимальное по модулю и одно минимальное по модулю.
Формат выходных данных
Выведите в выходной файл искомое произведение с 3 знаками после десятичной точки или 0, если между максимальным и минимальным по модулю элементом нет других элементов.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
18.12.2013, 15:53     Найти произведение элементов массива, расположенных между максимальным по модулю и минимальным по модулю элементами
Посмотрите здесь:

Произведение элементов массива, расположенных между максимальным по модулю и минимальным по модулю элементами C++
Одномерный массив ( вычислить произведение элементов массива, расположенных между максимальным по модулю и минимальным по модулю элементами) C++
вычислить произведение элементов массива, расположенных между максимальным по модулю и минимальным по модулю элементами C++
C++ Найти произведение элементов массива, расположенных между максимальным по модулю и минимальным по модулю элементами
Найти произведение элементов массива, расположенных между максимальным по модулю и минимальным по модулю элементами C++
Одномерный массив. Найти произведение элементов массива, расположенных между максимальным и минимальным элементами C++
C++ Вычислить произведение элементов массива, расположенных между максимальным и минимальным по модулю элементами
C++ Найти произведение элементов массива, расположенных между максимальным и минимальным элементами

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
filimoncc
1 / 1 / 1
Регистрация: 02.12.2013
Сообщений: 101
18.12.2013, 15:57  [ТС]     Найти произведение элементов массива, расположенных между максимальным по модулю и минимальным по модулю элементами #2
Корректное условие:
Миниатюры
Найти произведение элементов массива, расположенных между максимальным по модулю и минимальным по модулю элементами  
filimoncc
1 / 1 / 1
Регистрация: 02.12.2013
Сообщений: 101
18.12.2013, 20:38  [ТС]     Найти произведение элементов массива, расположенных между максимальным по модулю и минимальным по модулю элементами #3
ап темы

Добавлено через 14 минут
есть набросок
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
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
#include "iostream"
#include "cmath"
#include "iomanip"
#include "stdafx.h"
 
int main()
{
    freopen("input.txt", "rt", stdin);
    freopen("output.txt", "wt", stdout);
    float n;
    std::cin >> n;
    if (n >= 1 && n <= 100)
    {
        float a[n];//объявляем массив
 
 
        for (int i = 0; i < n; i++)
        {
            std::cin >> a[i];
        }
        int one = 0, second;// One=0 если максимальный элемент стоит первым
        float maxim, minim;
        maxim = fabs(a[0]);
        minim = fabs(a[0]);
 
        for (int i = 1; i < n; i++)
        {
            if (maxim < fabs(a[i])
            {
                maxim = fabs(a[i]);//нашел максимум
                one = i;
            }
 
            if (minim >= fabs(a[i])
            {
                minim = fabs(a[i]);//нашел минимум
                second = i;
            }
        }
 
        if (one < second)//если максимальный элемент первее минимального, то выполняется цикл под условием
        {
            float s = 1;
            for (int j = one + 1; j < second; j++)
            {
                s *= a[j];
            }//считаем сумму меж макс. и миним.
            if (s = 1)
            {
                std::cout << setprecision(3) << 0 << endl;
 
            }
            else
                std::cout << setprecision(3) << s << endl;
 
        }
        else
        {
 
            float s = 1;
            for (int j = second + 1; j < one; j++)
            {
                s *= a[j];
            }//считаем сумму меж макс. и миним.
            if (s = 1)
            {
                std::cout << setprecision(3) << 0 << endl;
 
            }
            else
 
                std::cout << setprecision(3) << s << endl;
        }
 
    }
    return 0;
}
Добавлено через 34 минуты
up темы

Добавлено через 37 минут
поправьте код
Yandex
Объявления
18.12.2013, 20:38     Найти произведение элементов массива, расположенных между максимальным по модулю и минимальным по модулю элементами
Ответ Создать тему
Опции темы

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