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

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

Восстановить пароль Регистрация
 
Евгения Е
 Аватар для Евгения Е
0 / 0 / 0
Регистрация: 20.05.2014
Сообщений: 9
20.05.2014, 20:39     Вычислить среднее арифметическое элементов массива, расположенных между максимальным и минимальным элементами #1
Мое условие: Дан вещественный массив A[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
55
56
57
58
59
60
61
62
#include "stdafx.h"
#include <cstdlib>
#include <iostream>
using namespace std;
 
void main()
{
setlocale(LC_ALL, "Rus");
int n;
cout<<"Введите количество элементов N: ";
cin>>n;
double a[100];
double t;
cout<<"Введите элементы массива A: ";
for (int i = 0; i < n; i++)
{
cin>>t;
for (int j=0; j < i; j++)
if (a[j] == t)
{
cout<<"Ошибка"<<endl;
}
a[i] = t;
}
double min = a[0];
double max = a[0];
int i1 = 0, i2 = 0;
for (int i = 0; i < n; i++)
{
if (a[i] < min)
{
min = a[i];
i1 = i;
}
if (a[i] > max)
{
max = a[i];
i2 = i;
}
}
if (i1 + 1 == i2)
{
cout<<"Среднего арифметического нет"<<endl;
}
else
{
double s = 0;
if (i1<i2)
{
for (int i=i1+1; i<=i2-1; i++)
s+=a[i];
s = s/(i2 - i1 - 1);
}
else
{
for (int i=i2+1; i<=i1-1; i++)
s+=a[i];
s = s/(i1 - i2 - 1);
}
cout<<"Средне арифметическое s= "<<s<<endl;
}
system ("pause"); }
Помогите, пожалуйста! Когда я записываю одинаковые значения элементов, он пишет , как и должно быть "ошибка", но следует дальше циклу и считает среднее арифметическое, когда должен идти в начало цикла. Как исправить??
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
20.05.2014, 20:39     Вычислить среднее арифметическое элементов массива, расположенных между максимальным и минимальным элементами
Посмотрите здесь:

C++ Вычислить произведение элементов массива, расположенных между максимальным и минимальным элементами
C++ 2. В одномерном массиве найти среднее арифметическое для элементов, расположенных между максимальным и минимальным
Вычислить сумму отрицательных элементов массива и произведение элементов, расположенных между максимальным и минимальным элементами C++
вычислить произведение элементов массива, расположенных между максимальным и минимальным элементами; C++
вычислить произведение элементов массива, расположенных между максимальным и минимальным элементами; C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
dzrkot
zzzZZZ...
 Аватар для dzrkot
516 / 346 / 53
Регистрация: 11.09.2013
Сообщений: 1,977
20.05.2014, 21:10     Вычислить среднее арифметическое элементов массива, расположенных между максимальным и минимальным элементами #2
PS(забыл что элементы не должны повторяться)
это наглядное пособие как нельзя использовать STL, вызывая каждый раз в циклах и условиях функции из algorithm =))
написал чтобы поупражняться и не забыть как вообще писать
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
#include <ctime>
#include <cstdlib>
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
 
int main()
{
srand(time(0));
setlocale(LC_ALL, "Rus");
int size;
cout<<"Введите количество элементов: ";
cin>>size;
double sum=0,counter=0;
vector<int> a(size);
vector<int>::iterator it;
    for(it=a.begin();it!=a.end();it++)
    cout<<(*it=-10+rand()%20)<<endl;
 
cout<<"max:"<<*max_element(a.begin(),a.end())<<endl;
cout<<"min:"<<*min_element(a.begin(),a.end())<<endl;
if (max_element(a.begin(),a.end()) < min_element(a.begin(),a.end()))
    for (it=max_element(a.begin(),a.end());it!=min_element(a.begin(),a.end())+1;it++,counter++)
    cout<<(sum+=*it)<<endl;
else
    for (it=min_element(a.begin(),a.end());it!=max_element(a.begin(),a.end())+1;it++,counter++)
    cout<<(sum+=*it)<<endl;
 
cout<<endl<<"counter : "<<counter;
cout<<endl<<sum/counter;
}
Хедин
 Аватар для Хедин
73 / 68 / 36
Регистрация: 17.05.2014
Сообщений: 301
20.05.2014, 21:11     Вычислить среднее арифметическое элементов массива, расположенных между максимальным и минимальным элементами #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
#include <iostream>
 
using namespace std;
 
const int n = 10;
 
int main()
{
    int a[n];
    int i = 0;
    while (i < n)
    {
        int tmp;
        cout << "Введите a[" << i << "]:"; cin >> tmp;
        bool ok = true;
        for (int j = 0; j < i; j++)
            if (a[j] == tmp)
            {
                ok = false;
                break;
            }
        if (ok) a[i++] = tmp;
        else cout << "Ошибка!" << endl;
    }
    system("pause");
    return 0;
}
dzrkot
zzzZZZ...
 Аватар для dzrkot
516 / 346 / 53
Регистрация: 11.09.2013
Сообщений: 1,977
20.05.2014, 21:21     Вычислить среднее арифметическое элементов массива, расположенных между максимальным и минимальным элементами #4
вот теперь не совпадает, но и размерность другая, делать с размерностью лень, но не сложно
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
#include <ctime>
#include <cstdlib>
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
 
int main()
{
srand(time(0));
setlocale(LC_ALL, "Rus");
int size;
cout<<"Введите количество элементов: ";
cin>>size;
double sum=0,counter=0;
vector<int> a(size);
vector<int>::iterator it;
vector<int>::iterator it2;
    for(it=a.begin();it!=a.end();it++)
    *it=-40+rand()%50;
 
    for(it=a.begin();it!=a.end();it++)
        for(it2=it+1;it2!=a.end();it2++)
        if (*it==*it2)
            {
            a.erase(it2);
            --it2;
            }
    for(it=a.begin();it!=a.end();it++)
        cout<<*it<<endl;
cout<<"max:"<<*max_element(a.begin(),a.end())<<endl;
cout<<"min:"<<*min_element(a.begin(),a.end())<<endl;
if (max_element(a.begin(),a.end()) < min_element(a.begin(),a.end()))
    for (it=max_element(a.begin(),a.end());it!=min_element(a.begin(),a.end())+1;it++,counter++)
    cout<<(sum+=*it)<<endl;
else
    for (it=min_element(a.begin(),a.end());it!=max_element(a.begin(),a.end())+1;it++,counter++)
    cout<<(sum+=*it)<<endl;
 
cout<<endl<<"counter : "<<counter;
cout<<endl<<sum/counter;
}
Darkos
5 / 5 / 4
Регистрация: 16.05.2014
Сообщений: 74
20.05.2014, 22:05     Вычислить среднее арифметическое элементов массива, расположенных между максимальным и минимальным элементами #5
Цитата Сообщение от Евгения Е Посмотреть сообщение
Как исправить?
Не проще через goto?
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
#include "stdafx.h"
#include <cstdlib>
#include <iostream>
using namespace std;
 
void main()
{
setlocale(LC_ALL, "Rus");
int n;
cout<<"Введите количество элементов N: ";
cin>>n;
double a[100];
double t;
cout<<"Введите элементы массива A: ";
for (int i = 0; i < n; i++)
{
error:
cin>>t;
for (int j=0; j < i; j++)
if (a[j] == t)
{
cout<<"Ошибка"<<endl;
}
a[i] = t;
goto error;
}
double min = a[0];
double max = a[0];
int i1 = 0, i2 = 0;
for (int i = 0; i < n; i++)
{
if (a[i] < min)
{
min = a[i];
i1 = i;
}
if (a[i] > max)
{
max = a[i];
i2 = i;
}
}
if (i1 + 1 == i2)
{
cout<<"Среднего арифметического нет"<<endl;
}
else
{
double s = 0;
if (i1<i2)
{
for (int i=i1+1; i<=i2-1; i++)
s+=a[i];
s = s/(i2 - i1 - 1);
}
else
{
for (int i=i2+1; i<=i1-1; i++)
s+=a[i];
s = s/(i1 - i2 - 1);
}
cout<<"Средне арифметическое s= "<<s<<endl;
}
system ("pause"); }
dzrkot
zzzZZZ...
 Аватар для dzrkot
516 / 346 / 53
Регистрация: 11.09.2013
Сообщений: 1,977
20.05.2014, 22:07     Вычислить среднее арифметическое элементов массива, расположенных между максимальным и минимальным элементами #6
Цитата Сообщение от Darkos Посмотреть сообщение
Не проще через goto?
лучше забудьте про goto, это показатель "плохого стиля", ...корень всего зла и происки западных спецслужб, а так же пропаганда СМИ)
Darkos
5 / 5 / 4
Регистрация: 16.05.2014
Сообщений: 74
20.05.2014, 22:12     Вычислить среднее арифметическое элементов массива, расположенных между максимальным и минимальным элементами #7
Цитата Сообщение от dzrkot Посмотреть сообщение
лучше забудьте про goto, это показатель "плохого стиля"
А что в нем плохого? Довольно удобно между прочем.
dzrkot
zzzZZZ...
 Аватар для dzrkot
516 / 346 / 53
Регистрация: 11.09.2013
Сообщений: 1,977
20.05.2014, 22:15     Вычислить среднее арифметическое элементов массива, расположенных между максимальным и минимальным элементами #8
Цитата Сообщение от Darkos Посмотреть сообщение
А что в нем плохого? Довольно удобно между прочем.
много споров на эту тему, в простых программах мб и удобно, но в более сложных это смерти подобно, в качестве костыля ещё можно воспользоваться порой если сроки поджимают, но имхо надо уметь строить программы без них
Darkos
5 / 5 / 4
Регистрация: 16.05.2014
Сообщений: 74
20.05.2014, 22:22     Вычислить среднее арифметическое элементов массива, расположенных между максимальным и минимальным элементами #9
Цитата Сообщение от dzrkot Посмотреть сообщение
в простых программах мб и удобно, но в более сложных это смерти подобно, в качестве костыля ещё можно воспользоваться порой если сроки поджимают, но имхо надо уметь строить программы без них
Здесь я с вами согласен, но данный пример и есть простая программа, и зачем писать кучу лишнего кода если можно обойтись двумя строчками goto?
dzrkot
zzzZZZ...
 Аватар для dzrkot
516 / 346 / 53
Регистрация: 11.09.2013
Сообщений: 1,977
20.05.2014, 22:25     Вычислить среднее арифметическое элементов массива, расположенных между максимальным и минимальным элементами #10
Цитата Сообщение от Darkos Посмотреть сообщение
Здесь я с вами согласен, но данный пример и есть простая программа, и зачем писать кучу лишнего кода если можно обойтись двумя строчками goto
чтобы потом уметь обходиться без них я полагаю.... вообще зачем решать задачи по программированию? затем чтобы развивать мышление, осваивать новые приёмы и т.п. ... будет ли необходим в дальнейшем goto? Честно скажу я ещё ни разу его не использовал даже в костылях
Darkos
5 / 5 / 4
Регистрация: 16.05.2014
Сообщений: 74
20.05.2014, 22:30     Вычислить среднее арифметическое элементов массива, расположенных между максимальным и минимальным элементами #11
Цитата Сообщение от dzrkot Посмотреть сообщение
будет ли необходим в дальнейшем goto?
Будет или нет я не знаю. Но во всяком случае если знать как им пользоваться это не есть плохо. А идею вы мне хорошею подали. Буду учится обходится без goto.
ValeryS
Модератор
6375 / 4841 / 443
Регистрация: 14.02.2011
Сообщений: 16,044
20.05.2014, 22:53     Вычислить среднее арифметическое элементов массива, расположенных между максимальным и минимальным элементами #12
Цитата Сообщение от Darkos Посмотреть сообщение
А что в нем плохого?
Он нарушает модульность
у модуля должен быть один вход один выход
а ГоТо может сделать и вход в середину модуля и выход из модуля
в результате получается принцип "спагетти" очень трудно потом сопровождать код, и править ошибки
что хорошо для ассемблера, для языка высокого уровня не годится

Цитата Сообщение от Darkos Посмотреть сообщение
Буду учится обходится без goto.
а чтобы обходится достаточно сделать функцию проверки

например так
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
bool Veryfy( int* arr, int size, int val)
{
  for(int i=0; i<size;i++)
    if(arr[i]==val)
       return false;
 return true;
}
 
..........................................
i=0;
while(i<M)
{
  int tmp;
  cin>>tmp;
   if(Veryfy(arr,i,tmp)
      arr[i++]=tmp;
  else
   cout<<"Error"<<endl;
}
Добавлено через 8 минут
Цитата Сообщение от Darkos Посмотреть сообщение
C++
1
2
3
4
5
6
7
8
9
10
11
12
for (int i = 0; i < n; i++)
{
error:
cin>>t;
for (int j=0; j < i; j++)
if (a[j] == t)
{
cout<<"Ошибка"<<endl;
}
a[i] = t;
goto error;
}
я правильно понял что если ошибка то мы все равно записываем число и в любом случае переходим по goto
в результате i++ не происходит и вечный цикл и пишем по одному и тому же адресу?
Darkos
5 / 5 / 4
Регистрация: 16.05.2014
Сообщений: 74
21.05.2014, 07:29     Вычислить среднее арифметическое элементов массива, расположенных между максимальным и минимальным элементами #13
Цитата Сообщение от ValeryS Посмотреть сообщение
for (int i = 0; i < n; i++)
C++
1
2
3
4
5
6
7
8
9
10
11
{
error:
cin>>t;
for (int j=0; j < i; j++)
if (a[j] == t)
{
cout<<"Ошибка"<<endl;
}
a[i] = t;
goto error;
}
я правильно понял что если ошибка то мы все равно записываем число и в любом случае переходим по goto
в результате i++ не происходит и вечный цикл и пишем по одному и тому же адресу?
Там опечатка, должно быть так
C++
1
2
3
4
5
6
7
8
9
10
11
12
for (int i = 0; i < n; i++)
    {
    error:
        cin>>t;
        for (int j=0; j < i; j++)
        if (a[j] == t)
        {
            cout<<"Ошибка"<<endl;
            goto error;
        }
        a[i] = t;
    }
Евгения Е
 Аватар для Евгения Е
0 / 0 / 0
Регистрация: 20.05.2014
Сообщений: 9
21.05.2014, 15:20  [ТС]     Вычислить среднее арифметическое элементов массива, расположенных между максимальным и минимальным элементами #14
Мне нельзя использовать указатели
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
24.05.2014, 22:42     Вычислить среднее арифметическое элементов массива, расположенных между максимальным и минимальным элементами
Еще ссылки по теме:

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

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

Или воспользуйтесь поиском по форуму:
Хедин
 Аватар для Хедин
73 / 68 / 36
Регистрация: 17.05.2014
Сообщений: 301
24.05.2014, 22:42     Вычислить среднее арифметическое элементов массива, расположенных между максимальным и минимальным элементами #15
Евгения Е, вам такой код не подходит? Здесь не используется goto
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
#include <iostream>
 
using namespace std;
 
const int n = 10;
 
int main()
{
    int a[n];
    int i = 0;
    while (i < n)
    {
        int tmp;
        cout << "Введите a[" << i << "]:"; cin >> tmp;
        bool ok = true;
        for (int j = 0; j < i; j++)
            if (a[j] == tmp)
            {
                ok = false;
                break;
            }
        if (ok) a[i++] = tmp;
        else cout << "Ошибка!" << endl;
    }
    system("pause");
    return 0;
}
Yandex
Объявления
24.05.2014, 22:42     Вычислить среднее арифметическое элементов массива, расположенных между максимальным и минимальным элементами
Ответ Создать тему
Опции темы

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