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

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

Войти
Регистрация
Восстановить пароль
 
Викторрр
0 / 0 / 0
Регистрация: 22.10.2012
Сообщений: 44
26.01.2014, 13:38     Получить новый массив, содержащий те элементы, которые меньше среднего арифметического, удалив их из исходного #1
Дан массив a1,...,a50. Получить новый массив, содержащий те элементы,
которые меньше среднего арифметического, удалив их из исходного.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
26.01.2014, 13:38     Получить новый массив, содержащий те элементы, которые меньше среднего арифметического, удалив их из исходного
Посмотрите здесь:

Создать новый массив, содержащий только те элементы, которые встрачаются в исходном один раз C++
Написать функцию, которая в массиве вещественных чисел обнуляет все элементы, которые меньше среднего C++
C++ Вывести массив, предварительно удалив элементы меньшие среднего арифметического
Сжать массив, удалив из него все элементы, которые лежат в интервале [a,b]. Освободившиеся в конце элементы массива заполнить нулями. C++
Вывести на экран элементы массива, которые больше среднего арифметического всех его элементов C++
Создать новый файл, содержащий элементы исходного файла в обратном порядке C++
Получить новый массив,который отличается от исходного тем, что все нечетные элементы удвоены C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
TheDanger227
 Аватар для 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");
}
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");
}
cooller
 Аватар для cooller
564 / 532 / 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;
Не легче ли?
Tulosba
:)
Эксперт С++
4382 / 3225 / 297
Регистрация: 19.02.2013
Сообщений: 9,044
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>
TheDanger227
 Аватар для TheDanger227
6 / 6 / 1
Регистрация: 27.11.2012
Сообщений: 58
26.01.2014, 22:35     Получить новый массив, содержащий те элементы, которые меньше среднего арифметического, удалив их из исходного #6
Ваш тоже не удаляет Просто сдвигает вправо и не выводит. Я думал ТС сам доделает добавив новый массив и заполнив его ненулевыми элементами.
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
27.01.2014, 08:10     Получить новый массив, содержащий те элементы, которые меньше среднего арифметического, удалив их из исходного
Еще ссылки по теме:

C++ В двумирному массиве заменить на ноль те элементы, которые имеют нечетное сумму индексов и больше среднего арифметического значений элементов массива
C++ В массив С перенести те элементы А, которые меньше min(В), и те элементы B, которые больше max(A)
Получить новый массив, как разность между элементами исходного массива и его среднего арифметического с++ C++
C++ Записать элементы, которые больше среднего арифметического, в новый массив
C++ Получить новый массив из старого удалив элементы с заданным значением

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

Или воспользуйтесь поиском по форуму:
Tulosba
:)
Эксперт С++
4382 / 3225 / 297
Регистрация: 19.02.2013
Сообщений: 9,044
27.01.2014, 08:10     Получить новый массив, содержащий те элементы, которые меньше среднего арифметического, удалив их из исходного #7
TheDanger227, да будет вам известно, что удаление в данном случае подразумевается логическое, а не физическое. В частности, даже std::vector не перераспределяет память, выделенную под элементы, при вызове vector::erase. Для эффективного уменьшения емкости нужно либо вызвать shrink_to_fit, либо использовать прием со swap.
Yandex
Объявления
27.01.2014, 08:10     Получить новый массив, содержащий те элементы, которые меньше среднего арифметического, удалив их из исходного
Ответ Создать тему
Опции темы

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