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

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

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

Удаление максимальных элементов из массива - C++

09.07.2011, 21:30. Просмотров 463. Ответов 3
Метки нет (Все метки)

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

Нахождение 3 максимальных элементов массива - C++
#include <iostream> #include <stdio.h> #include <stdlib.h> using namespace std; int main() { int *arr; // указатель для...

Выбрать n максимальных элементов из массива - C++
Есть структура: struct data { /* какте-то поля */ uint32_t num; // Число }; есть массив этой структуры ...

Определение максимальных элементов массива (С++) - C++
Всем добрый день) Задача следующая. Даны два массива, в одном 5 элементов, в другом 20. Определить индексы и значения максимальных...

Количество максимальных элементов массива - C++
Написал код рабочий по нахождению максимального элемента, но вот проблемка, не могу найти кол-во одинаковых максимальных элементов ...

Найти количество максимальных элементов массива - C++
Дан массив а,состоящий из n целых чисел (n<=100).Найти количество максимальных элементов массива

Вывести количество максимальных элементов массива - C++
Доброго всем вечера, задали написать программу которая выводит количество максимальных элементов массива... Я еще не очень розбираюсь в с++...

3
silent_1991
Эксперт С++
4986 / 3043 / 149
Регистрация: 11.11.2009
Сообщений: 7,027
Завершенные тесты: 1
09.07.2011, 22:01 #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
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
#include <stdio.h>
#include <stdlib.h>
 
double max_value(double *, size_t);
size_t count(double *, size_t, double);
size_t remove(double **, size_t, double);
double *make_copy(double *, size_t);
 
int main(void)
{
    double *arr;
    double *result_arr;
    size_t size;
    size_t result_size;
    size_t i;
 
    printf("Enter number of elements: ");
    scanf("%u", &size);
 
    arr = (double *)malloc(size * sizeof(double));
 
    for (i = 0; i < size; ++i)
    {
        printf("arr[%u] = ", i);
        scanf("%lf", &arr[i]);
    }
 
    result_arr = make_copy(arr, size);
 
    result_size = remove(&result_arr, size, max_value(arr, size));
 
    printf("Result array: ");
 
    for (i = 0; i < result_size; ++i)
        printf("%.2lf  ", result_arr[i]);
 
    printf("\n");
 
    free(arr);
    free(result_arr);
 
    return 0;
}
 
double max_value(double *arr, size_t size)
{
    double max = arr[0];
    size_t i;
 
    for (i = 1; i < size; ++i)
        if (max < arr[i])
            max = arr[i];
 
    return max;
}
 
size_t count(double *arr, size_t size, double elem)
{
    size_t count = 0;
    size_t i;
 
    for (i = 0; i < size; ++i)
        if (arr[i] == elem)
            ++count;
 
    return count;
}
 
size_t remove(double **arr, size_t size, double elem)
{
    size_t result_size = size - count(*arr, size, elem);
    double *result_arr = (double *)malloc(result_size * sizeof(double));
    size_t i, j = 0;
 
    for (i = 0; i < size; ++i)
        if ((*arr)[i] != elem)
            result_arr[j++] = (*arr)[i];
 
    free(*arr);
 
    *arr = result_arr;
 
    return result_size;
}
 
double *make_copy(double *arr, size_t size)
{
    double *result_arr = (double *)malloc(size * sizeof(double));
    size_t i;
 
    for (i = 0; i < size; ++i)
        result_arr[i] = arr[i];
 
    return result_arr;
}
1
Skorpi
0 / 0 / 0
Регистрация: 08.07.2011
Сообщений: 7
09.07.2011, 22:20  [ТС] #3
silent_1991, благодарю! А не могли бы еще пожалуйста блок схему составить для нее?
0
silent_1991
Эксперт С++
4986 / 3043 / 149
Регистрация: 11.11.2009
Сообщений: 7,027
Завершенные тесты: 1
09.07.2011, 22:24 #4
Skorpi, нет, давайте-ка вы сами. Ничего сложного нет, на вики есть правило составления блок-схем.
0
09.07.2011, 22:24
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
09.07.2011, 22:24
Привет! Вот еще темы с ответами:

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

Найти произведение индексов L максимальных элементов массива - C++
Для массива А(n) найти произведение индексов L максимальных элементов, где 0&lt;=n&lt;=45. Число L ввести с клавиатуры. Значения элементов...

Удаление четных элементов массива,больших среднего арифметического всех элементов массива - C++
Доброго времени суток! Помогите пожалуйста) Вот задание:Из массива удалить четные элементы, имеющие значение больше среднего...

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


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

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

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