Форум программистов, компьютерный форум, киберфорум
Наши страницы
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.80/5: Рейтинг темы: голосов - 5, средняя оценка - 4.80
SonOfGabe
0 / 0 / 0
Регистрация: 17.12.2016
Сообщений: 17
#1

Работа с одномерными массивами

18.12.2016, 12:04. Просмотров 862. Ответов 5
Метки нет (Все метки)

1) массивы должны быть динамические – организовать вы-деление памяти;
2) значения элементов массива вводятся с клавиатуры;
3) каждый пункт задания оформлен в виде функции.

Для одномерного массива, состоящего из n вещественных чисел:
а) вычислить количество элементов массива, находящихся между макси-мальным и минимальным элементами;
б) вычислить среднее арифметическое положительных элементов массива;
в) заменить все элементы, предшествующие первому отрицательному
элементу, значением минимального элемента и распечатать массив.

Помогите, не знаю как через функции это оформить
0
Лучшие ответы (1)
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
18.12.2016, 12:04
Ответы с готовыми решениями:

Работа с одномерными массивами
Если в массиве отсутствуют нули, найти произведение его элементов. Затем...

Работа с одномерными массивами
Может кто-то сможет помочь .. В одномерном массиве ,который состоит из 15...

Работа с одномерными массивами: вставка, удаление
Доброго времени суток, помогите пожалуйста, чего то я недопонимаю что надо...

Работа с одномерными массивами с использованием процедур
Работа с одномерными массивами с использованием процедур Каждый пункт задания...

Работа с одномерными массивами. Коротышки собирали огурцы
Здравствуйте.Не могу понять, почему неправильно считает число максимумов и...

5
Jman
47 / 47 / 25
Регистрация: 11.10.2015
Сообщений: 575
Завершенные тесты: 4
18.12.2016, 18:36 #2
А вы для начала код скиньте - без функций, что написали.
0
SonOfGabe
0 / 0 / 0
Регистрация: 17.12.2016
Сообщений: 17
18.12.2016, 18:47  [ТС] #3
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
#include <iostream>
using namespace std;
int main()
{
    setlocale(LC_ALL, "rus");
    int n;
    cout << "введите количество элементов массива: ";
    cin >> n;
    int* mas;
    mas = new int[n]; //выделяем место для массива через указатель
    int i, minI, zadA, maxI, l;
 
    double zadB, j, k;
    for (i = 0; i < n; i++)
        cin >> mas[i];
    //Задание а
    int* max = mas;
    int* min = mas;
    {
        for (int i = 1; i < n; i++)
            if (mas[i] > (*max))
                max = &mas[i];
        for (int i = 1; i < n; i++)
            if (mas[i - 1] < mas[i])
                minI = i - 1;
            else
                minI = i;
        maxI = (max - mas);
    }
    // Задание б
    k = 0;
    j = 0;
    for (i = 0; i < n; i++) //среднеарифметическое
        if (mas[i] > 0)
        {
            j = j + mas[i];
            k = k + 1;
        }
    zadB = j / k; //конец задания б
    //Задание С
    cout << "среднее арифметическое положительных элементов массива равно: " << zadB << endl;
    cout << "max:  " << (max - mas) + 1 << endl;
    cout << "min:  " << minI + 1 << endl;
    cout << "zadA:  " << sqrt(((maxI + 1) - (minI + 1)) * ((maxI + 1) - (minI + 1))) << endl;
    for (i = 0; i < n; i++)
        cout << mas[i];
    delete mas;
    system("pause");
    return 0;
}
У меня ещё не совем получилось задание а, и вообще не выходит задание с
0
Fixer_84
1038 / 653 / 648
Регистрация: 30.04.2016
Сообщений: 2,209
18.12.2016, 19:22 #4
Лучший ответ Сообщение было отмечено SonOfGabe как решение

Решение

SonOfGabe, вот ваша программа:

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
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
#include <iostream>
#include <float.h>
#include <cmath>
 
using namespace std;
 
double PositiveAverage(double* A, int N)
{
    int k;
    double sum;
    sum = k = 0;
    for (int i = 0; i < N; i++)
    {
        if (A[i] > 0)
        {
            sum += A[i];
            k++;
        }
    }
    return (double)sum / k;
}
 
int BetweenMinMax(double* A, int N)
{
    double min, max;
    int p, d, x, y;
    min = DBL_MAX;
    max = DBL_MIN;
    for (int i = 0; i < N; i++)
    {
        if (A[i] < min)
        {
            min = A[i];
            x = i;
        }
        if (A[i] > max)
        {
            max = A[i];
            y = i;
        }
    }
    if (x < y)
    {
        p = x;
        d = y;
    }
    else
    {
        p = y;
        d = x;
    }
    p++;
    return d - p;
}
 
void ReplaceWithFirstNeg(double* A, int N)
{
    double neg, min;
    int x;
    min = DBL_MAX;
    for (int i = N; i--;)
    {
        if (A[i] < 0)
        {
            neg = A[i];
            x = i;
        }
        if (A[i] < min)
            min = A[i];
    }
    for (int i = 0; i < x; i++)
    {
        A[i] = min;
    }
    for (int i = 0; i < N; i++)
    {
        cout << A[i] << " ";
    }
}
 
int main()
{
    int N;
    cout << "Введите размерность массива:" << endl;
    cout << "N = ";
    cin >> N;
    double* X = new double[N];
    cout << "Введите массив:" << endl;
    for (int i = 0; i < N; i++)
    {
        cin >> X[i];
    }
    cout << "Среднее арифметическое положительных элементов: ";
    cout << PositiveAverage(X, N) << endl;
    cout << "Количество между минимумом и максимумом: ";
    cout << BetweenMinMax(X, N) << endl;
    cout << "Массив после замены:" << endl;
    ReplaceWithFirstNeg(X, N);
    cout << endl;
    delete[] X;
    system("pause");
    return 0;
}
1
SonOfGabe
0 / 0 / 0
Регистрация: 17.12.2016
Сообщений: 17
18.12.2016, 20:56  [ТС] #5
Добавлено через 37 минут
Fixer_84, Огромное спасибо! Выручили, пошёл разбираться с переменными
0
SonOfGabe
0 / 0 / 0
Регистрация: 17.12.2016
Сообщений: 17
22.12.2016, 19:03  [ТС] #6
Fixer_84,
C++
1
2
min = DBL_MAX;
max = DBL_MIN;
А можете объяснить, почему именно эти значения?

Добавлено через 18 минут
Fixer_84, уже не нужно
0
22.12.2016, 19:03
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
22.12.2016, 19:03

Работа с текстовой информацией, одномерными массивами и матрицами.
Здравствуйте... Помогите решить задачу... Отблагадарю))) 2. Имеется N...

Работа с одномерными массивами: удаление, добавление, перестановка элементов
1) Сформировать массив из n элементов с помощью датчика случайных чисел (n...

Работа с одномерными массивами: удаление, добавление, перестановка элементов
1) Сформировать массив из n элементов с помощью датчика случайных чисел (n...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2018, vBulletin Solutions, Inc.
Рейтинг@Mail.ru