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

Удаление четных элементов массива,больших среднего арифметического всех элементов массива - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 16, средняя оценка - 4.69
AleX_73
0 / 0 / 0
Регистрация: 09.12.2011
Сообщений: 13
26.10.2012, 09:03     Удаление четных элементов массива,больших среднего арифметического всех элементов массива #1
Доброго времени суток! Помогите пожалуйста)
Вот задание:Из массива удалить четные элементы, имеющие значение больше среднего арифметического всех элементов массива.
Пример: из массива A[5]: 8 7 2 6 5 должен получиться
массив A[3]: 7 2 5 (среднее арифметическое всех элементов =(8+7+2+6+5)/5=5.6).

Вот что я написал:

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
#include "stdafx.h"
#include "conio.h"
#include "stdlib.h"
#include "time.h"
 
//функция печати массива
void printarr(int* arr, int size)
{
    for(int i = 0; i < size; i++)
    {
        printf("%d\n",arr[i]);
        printf("\n");
    }
}
 
//нахождение среднего арифметического всех элементов массива
int average(int* arr,int size)
{
    int sum = 0;
    for(int i = 0; i < size; ++i)
    {
        sum += arr[i];
    }
    return sum/size;
}
 
            
int _tmain(int size,int avr)    
{   
    
    printf("Enter size of the array: ");
    scanf_s("%d",&size);
    
    if(size < 0)
    {
        printf("Error: size must be > 0 \nPlease try again");
        _getch();
        return 0;
    }
    
    int* arr = new int[size];
    srand((unsigned)time(NULL));
    for(int i=0; i<size; i++)
    {
        arr[i] = 10 + rand()% 90;
        printf("%d\n",arr[i]);
    }
    
 
    printf("Average of the array elements: %d",average(arr,size));
    int newsize = 0;
    for(int i=0; i<size; i++)
    {   
        if(arr[i]%2!=0)
            
        arr[newsize++]=arr[i];
    }
    
    for(int i=0; i<newsize; i++)
    {
        printf("\n %d", arr[i]);
    }
    
    _getch();
}

Удаляются все четные элементы, а нужно чтобы удалялись четные элементы, большие среднего арифметического.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
26.10.2012, 09:03     Удаление четных элементов массива,больших среднего арифметического всех элементов массива
Посмотрите здесь:

определить количество элементов двумерного массива,которые меньше среднего арифметического значения всех элементов своей строки C++
C++ Посчитать количество элементов, отличающихся от среднего арифметического значения элементов массива
Массив. Найти количество элементов, меньших среднего арифметического положительных элементов этого массива C++
Найти количество элементов в каждой строке, больших среднего арифметического элементов этой строки. C++
C++ Реализовать нахождение среднего арифметического элементов массива
C++ в массиве . найти произведение нулевых элементов, количество элементов, превышающих значение среднего арифметического элементов массива
в массиве . найти произведение ненулевых элементов, количество элементов, превышающих значение среднего арифметического элементов массива C++
C++ Функция расчета среднего арифметического всех четных элементов одномерного массива

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
defer
秘密
 Аватар для defer
555 / 235 / 3
Регистрация: 29.11.2010
Сообщений: 783
26.10.2012, 09:27     Удаление четных элементов массива,больших среднего арифметического всех элементов массива #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
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
#include "conio.h"
#include "stdlib.h"
#include "stdio.h"
#include "time.h"
 
//функция печати массива
void printarr(double* arr, double size)
{
    for(int i = 0; i < size; i++)
    {
        printf("%f\n",arr[i]);
        printf("\n");
    }
}
 
//нахождение среднего арифметического всех элементов массива
double average(int* arr,int size)
{
    double sum = 0;
    for(int i = 0; i < size; ++i)
    {
        sum += arr[i];
    }
    return sum/size;
}
 
 
int main()
{
    int size;
    double avr;
    printf("Enter size of the array: ");
    scanf("%d",&size);
 
    if(size < 0)
    {
        printf("Error: size must be > 0 \nPlease try again");
        return 0;
    }
 
    int* arr = new int[size];
    srand((unsigned)time(NULL));
 
    for(int i=0; i<size; i++)
    {
        arr[i] = 10 + rand()% 90;
        printf("%d\n",arr[i]);
    }
 
    avr=average(arr,size);
    printf("Average of the array elements: %0.1f",avr);
 
    int newsize = 0;
 
    for(int i=0; i<size; i++)
    {
        if(arr[i]%2!=0 ||(arr[i]%2==0&&arr[i]<avr) )
            arr[newsize++]=arr[i];
    }
 
    for(int i=0; i<newsize; i++)
    {
        printf("\n %d", arr[i]);
    }
 
    return 0;
}
AleX_73
0 / 0 / 0
Регистрация: 09.12.2011
Сообщений: 13
26.10.2012, 12:58  [ТС]     Удаление четных элементов массива,больших среднего арифметического всех элементов массива #3
defer, Все работает! Спасибо большое
Yandex
Объявления
26.10.2012, 12:58     Удаление четных элементов массива,больших среднего арифметического всех элементов массива
Ответ Создать тему
Опции темы

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