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

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

20.05.2014, 20:39. Показов 4966. Ответов 14
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Мое условие: Дан вещественный массив 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"); }
Помогите, пожалуйста! Когда я записываю одинаковые значения элементов, он пишет , как и должно быть "ошибка", но следует дальше циклу и считает среднее арифметическое, когда должен идти в начало цикла. Как исправить??
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
20.05.2014, 20:39
Ответы с готовыми решениями:

Найти среднее арифметическое элементов массива расположенных между максимальным и минимальным элементами
Дан вещественный массив А в котором не повторяются значения элементов. Найти среднее арифметическое элементов массива расположенных между...

Найти среднее арифметическое элементов, расположенных между первым минимальным и последним максимальным элементами
Найти среднее арифметическое элементов, расположенных между первым минимальным и последним максимальным элементами. Если последний...

Найти среднее арифметическое элементов массива, расположенных между максимальным и минимальным
Помогите пожалуйста я не фига не понимаю с си. Ps если можно распишите по подробней. В одномерном массиве найти среднее...

14
zzzZZZ...
 Аватар для dzrkot
527 / 358 / 94
Регистрация: 11.09.2013
Сообщений: 2,041
20.05.2014, 21:10
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;
}
0
 Аватар для Хедин
76 / 71 / 55
Регистрация: 17.05.2014
Сообщений: 301
20.05.2014, 21:11
Евгения Е, вот так будет выглядеть заполнение массива разными элементами
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;
}
0
zzzZZZ...
 Аватар для dzrkot
527 / 358 / 94
Регистрация: 11.09.2013
Сообщений: 2,041
20.05.2014, 21:21
вот теперь не совпадает, но и размерность другая, делать с размерностью лень, но не сложно
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;
}
0
8 / 8 / 12
Регистрация: 16.05.2014
Сообщений: 151
20.05.2014, 22:05
Цитата Сообщение от Евгения Е Посмотреть сообщение
Как исправить?
Не проще через 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"); }
0
zzzZZZ...
 Аватар для dzrkot
527 / 358 / 94
Регистрация: 11.09.2013
Сообщений: 2,041
20.05.2014, 22:07
Цитата Сообщение от Darkos Посмотреть сообщение
Не проще через goto?
лучше забудьте про goto, это показатель "плохого стиля", ...корень всего зла и происки западных спецслужб, а так же пропаганда СМИ)
0
8 / 8 / 12
Регистрация: 16.05.2014
Сообщений: 151
20.05.2014, 22:12
Цитата Сообщение от dzrkot Посмотреть сообщение
лучше забудьте про goto, это показатель "плохого стиля"
А что в нем плохого? Довольно удобно между прочем.
0
zzzZZZ...
 Аватар для dzrkot
527 / 358 / 94
Регистрация: 11.09.2013
Сообщений: 2,041
20.05.2014, 22:15
Цитата Сообщение от Darkos Посмотреть сообщение
А что в нем плохого? Довольно удобно между прочем.
много споров на эту тему, в простых программах мб и удобно, но в более сложных это смерти подобно, в качестве костыля ещё можно воспользоваться порой если сроки поджимают, но имхо надо уметь строить программы без них
0
8 / 8 / 12
Регистрация: 16.05.2014
Сообщений: 151
20.05.2014, 22:22
Цитата Сообщение от dzrkot Посмотреть сообщение
в простых программах мб и удобно, но в более сложных это смерти подобно, в качестве костыля ещё можно воспользоваться порой если сроки поджимают, но имхо надо уметь строить программы без них
Здесь я с вами согласен, но данный пример и есть простая программа, и зачем писать кучу лишнего кода если можно обойтись двумя строчками goto?
0
zzzZZZ...
 Аватар для dzrkot
527 / 358 / 94
Регистрация: 11.09.2013
Сообщений: 2,041
20.05.2014, 22:25
Цитата Сообщение от Darkos Посмотреть сообщение
Здесь я с вами согласен, но данный пример и есть простая программа, и зачем писать кучу лишнего кода если можно обойтись двумя строчками goto
чтобы потом уметь обходиться без них я полагаю.... вообще зачем решать задачи по программированию? затем чтобы развивать мышление, осваивать новые приёмы и т.п. ... будет ли необходим в дальнейшем goto? Честно скажу я ещё ни разу его не использовал даже в костылях
0
8 / 8 / 12
Регистрация: 16.05.2014
Сообщений: 151
20.05.2014, 22:30
Цитата Сообщение от dzrkot Посмотреть сообщение
будет ли необходим в дальнейшем goto?
Будет или нет я не знаю. Но во всяком случае если знать как им пользоваться это не есть плохо. А идею вы мне хорошею подали. Буду учится обходится без goto.
0
Модератор
Эксперт по электронике
8979 / 6745 / 921
Регистрация: 14.02.2011
Сообщений: 23,859
20.05.2014, 22:53
Цитата Сообщение от 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++ не происходит и вечный цикл и пишем по одному и тому же адресу?
0
8 / 8 / 12
Регистрация: 16.05.2014
Сообщений: 151
21.05.2014, 07:29
Цитата Сообщение от 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 / 0
Регистрация: 20.05.2014
Сообщений: 11
21.05.2014, 15:20  [ТС]
Мне нельзя использовать указатели
0
 Аватар для Хедин
76 / 71 / 55
Регистрация: 17.05.2014
Сообщений: 301
24.05.2014, 22:42
Евгения Е, вам такой код не подходит? Здесь не используется 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;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
24.05.2014, 22:42
Помогаю со студенческими работами здесь

Найти среднее арифметическое элементов массива между максимальным и минимальным элементами
Дан массив из 20 вещественных чисел. Найти среднее арифметическое элементов массива между максимальным и минимальным элементом массива,...

Вычислить произведение элементов массива, расположенных между максимальным и минимальным элементами
#include &lt;conio.h&gt; using namespace std; int main() { setlocale(LC_ALL, &quot;RUS&quot;); const int N=15; int i; double mas,...

Вычислить произведение элементов массива, расположенных между максимальным и минимальным элементами
В одномерном массиве, состоящем из n вещественных элементов, вычислить: 2) произведение элементов массива, расположенных между...

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

Вычислить произведение элементов массива, расположенных между максимальным и минимальным элементами
#include &quot;stdafx.h&quot; #include &lt;conio.h&gt; const int N=4; int main() { int mas={1, 2,3,4,}; bool flag1=0, flag2=0, flag3=0; ...


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

Или воспользуйтесь поиском по форуму:
15
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru