Форум программистов, компьютерный форум, киберфорум
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Викторрр
0 / 0 / 0
Регистрация: 22.10.2012
Сообщений: 44
#1

Получить новый массив, содержащий те элементы, которые меньше среднего арифметического, удалив их из исходного - C++

26.01.2014, 13:38. Просмотров 504. Ответов 6
Метки нет (Все метки)

Дан массив a1,...,a50. Получить новый массив, содержащий те элементы,
которые меньше среднего арифметического, удалив их из исходного.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
26.01.2014, 13:38
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Получить новый массив, содержащий те элементы, которые меньше среднего арифметического, удалив их из исходного (C++):

Получить новый массив, как разность между элементами исходного массива и его среднего арифметического с++ - C++
Дан массив А ( 2.2,1.9,2.4,1.7,2.5,1,8,2.1,1.6 } . Найти среднее арифметическое значение элементов этого массива и получить новый массив...

Записать элементы, которые больше среднего арифметического, в новый массив - C++
В общем есть программа, которая находит среднее арифметическое и записывает элементы, которые больше среднего арифметического в новый...

Вывести массив, предварительно удалив элементы меньшие среднего арифметического - C++
Необходимо ввести массив вещественных чисел и вывести его, предварительно удалив элементы меньшие среднего арифметического. Буду...

Получить новый массив из старого удалив элементы с заданным значением - C++
Вот задача: Программа получения нового массива из старого массива удалением каждый раз числа 5 из старого массива. К примеру в массиве...

Создать новый массив, содержащий только те элементы, которые встрачаются в исходном один раз - C++
имеется массив из 4-х элементов. создать новый массив,содержащий только те элементы,которые в предыдущем встречаются один раз.

Получить новый массив,который отличается от исходного тем, что все нечетные элементы удвоены - C++
нужно получить новый массив,который отличается от исходного тем, что все нечетные элементы удвоены. (-20;20)

6
TheDanger227
6 / 6 / 1
Регистрация: 27.11.2012
Сообщений: 58
26.01.2014, 14:19 #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
#include <iostream>
#include <ctime> 
 
using namespace std;
 
int main()
{
    srand(time(0));
    setlocale(0,"Rus");
    int mas[50];
    double srd=0;
    for(int i=0;i<50;i++)
    {
        mas[i]=rand()%8+1;
        srd+=mas[i];
    }
    for(int i=0;i<50;i++)
    {
        cout<<mas[i]<<" ";
    }
    srd/=50;
    cout<<"\nСреднее арифметическое: "<<srd;
    for(int i=0;i<50;i++)
    {
        if(mas[i]<srd)
        {
            mas[i]=0;
        }
    }
    cout<<"\n";
    for(int i=0;i<50;i++)
    {
        cout<<mas[i]<<" ";
    }
    cout<<"\n";
    system("pause");
}
0
vovacreme
-16 / 61 / 13
Регистрация: 14.01.2014
Сообщений: 145
26.01.2014, 19:43 #3
TheDanger227, ваш код не удаляет элементы из массива. правильно будет так:
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
#include <iostream>
#include <ctime> 
 
using namespace std;
 
int main()
{
    srand(time(0));
    setlocale(0,"Rus");
    int size = 10;
    int * mas = new int[size];
    double srd=0;
    for(int i=0;i<size;i++)
    {
        mas[i]=rand()%8+1;
        srd+=mas[i];
    }
    for(int i=0;i<size;i++)
    {
        cout<<mas[i]<<" ";
    }
    srd/=size;
    cout<<"\nСреднее арифметическое: "<<srd;
    for(int i=0;i<size;i++)
    {
        while (i < size && mas[i] < srd)
        {
            for (int j = i; j < size-1; j++)
                mas[j] = mas[j+1];
            --size;
        }
    }
    cout<<"\n";
    for(int i=0;i<size;i++)
        cout<<mas[i]<<" ";
    cout<<"\n";
    system("pause");
}
1
cooller
565 / 533 / 120
Регистрация: 25.12.2013
Сообщений: 1,456
26.01.2014, 20:28 #4
Викторрр,
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
#include<iostream>
#include<cstdlib>
#include<ctime>
#include<iterator>
#include<algorithm>
#include<numeric>
int main()
{
    std::vector <int> Vector = {4,8,2,-6,4,2,7,4,7,4,23,7,4,8,6,3};
    std::cout<<"Array:\n";
    std::copy(Vector.begin(),Vector.end(),std::ostream_iterator<int>(std::cout," "));
    double average = static_cast<double>(std::accumulate(Vector.begin(),Vector.end(),0))/Vector.size();
    std::cout<<"\nAverage:"<<average;
    size_t CountDeleteElements(0);
    for(auto it = Vector.begin(); it!=Vector.end();)
        *it<average?Vector.erase(it):it++;
    std::cout<<"\nNew array:\n";
    std::copy(Vector.begin(),Vector.end(),std::ostream_iterator<int>(std::cout," "));
}
Добавлено через 14 минут
vovacreme, Перемудрил с удалением,ИМХО
C++
1
2
3
4
    size_t DeleteElements(0);
    for(size_t i=0; i<size; i++)
        mas[i]>srd?mas[i - DeleteElements] = mas[i]:DeleteElements++;
    size-=DeleteElements;
Не легче ли?
1
Tulosba
:)
Эксперт С++
4397 / 3233 / 297
Регистрация: 19.02.2013
Сообщений: 9,045
26.01.2014, 20:37 #5
cooller_94, чтоб std::accumulate дал результат в double, можно было просто начальное значение задать как 0.0
Удаление элемента должно быть организовано так чтобы итератор не становился недействительным:
C++
1
2
3
4
5
for(auto it = Vector.begin(); it!=Vector.end();)
{
   if( *it<average ) it = Vector.erase(it);
   else it++;
}
Или даже так:
C++
1
2
auto it = std::remove_if( Vector.begin(), Vector.end(), [average](int i){ return i<average; } );
Vector.erase( it, Vector.end() );
P.S. и лишние хедеры
C++
1
2
#include<cstdlib>
#include<ctime>
1
TheDanger227
6 / 6 / 1
Регистрация: 27.11.2012
Сообщений: 58
26.01.2014, 22:35 #6
Ваш тоже не удаляет Просто сдвигает вправо и не выводит. Я думал ТС сам доделает добавив новый массив и заполнив его ненулевыми элементами.
0
Tulosba
:)
Эксперт С++
4397 / 3233 / 297
Регистрация: 19.02.2013
Сообщений: 9,045
27.01.2014, 08:10 #7
TheDanger227, да будет вам известно, что удаление в данном случае подразумевается логическое, а не физическое. В частности, даже std::vector не перераспределяет память, выделенную под элементы, при вызове vector::erase. Для эффективного уменьшения емкости нужно либо вызвать shrink_to_fit, либо использовать прием со swap.
0
27.01.2014, 08:10
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
27.01.2014, 08:10
Привет! Вот еще темы с ответами:

Создать новый файл, содержащий элементы исходного файла в обратном порядке - C++
Дан файл целых чисел. Создать новый файл, содержащий те же элемен-ты, что и исходный файл, но в обратном порядке. помогите буду очень при...

определить количество элементов двумерного массива,которые меньше среднего арифметического значения всех элементов своей строки - C++
дан вещественный массив A. определить количество элементов массива,которые меньше среднего арифметического значения всех элементов своей...

Вывести на экран элементы массива, которые больше среднего арифметического всех его элементов - C++
Ребят помогите пожалуйста решить два массива, а то мне трудно они даються=) 1)Дан массив А из N элементов. Вывести на экран элементы...

В массив С перенести те элементы А, которые меньше min(В), и те элементы B, которые больше max(A) - C++
Ввести массивы А и В. В массив С перенести те элементы массива А , которые меньше минимального элемента массива В , и те элементы массива В...


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

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

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