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

Сделать так, чтобы максимальный элемент массива был удален, а если их несколько, то все

14.12.2017, 12:49. Показов 1473. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Нужно сделать так, чтобы максимальный элемент массива был удален, а если их несколько, то все.
Затем сформировать уже новый массив, без максимальных элементов. Как это сделать?

Вот мой код:

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
# include <iostream>
# include <conio.h>
# include <locale>
# include <time.h>
# include <cstdlib>
 
using namespace std;
 
void BBOD(int a[], int n);
void BbIBOD(int a[], int n);
void MAX(int a[], int n);
 
void main()
{
    setlocale(LC_ALL, "");
 
    int a[20];
    int n, k;
 
 
    cout << "Введите количество элементов массива "; cin >> n;
 
    do {
        cout << "1 - Ввод массива целых чисел; " << endl;
        cout << "2 - Вывод массива в строку; " << endl;
        cout << "3 - 1) Найти максимальный элемент; " << endl;
        cout << "    2) Найти количество эллементов имеющих максимальное значение; " << endl;
        cout << "    3) Удалить все максимальные значения; " << endl;
        cout << "4 - Выход из программы." << endl;
        cout << " Укажите номер пункта меню - " << endl; cin >> k;
 
        switch (k)
        {
        case 1: BBOD(a, n); break;
        case 2: BbIBOD(a, n); break;
        case 3: MAX(a, n); break;
        case 4: cout << "4 - Выход из программы." << endl; break;
        default: cout << "Такого пункта программы нет!" << endl;
        }
        if (k == 4) break;
    } while (true);
    _getch();
}
 
void BBOD(int a[], int n)
{
    cout << "Введите элементы целочисленного массива:" << endl;
    for (int i = 0; i < n; i++)
        cin >> a[i];
}
 
void BbIBOD(int a[], int n)
{
    cout << "Получен целочисленный массив с элементами: " << endl;
    for (int i = 0; i < n; i++)
        cout << "a[" << i << "]=" << a[i] << "\t";
    cout << endl;
}
 
void MAX(int a[], int n)
{
    int max = a[0];
    int count = 0;
 
    for (int i = 0; i < n; i++) {
        if (a[i] >= max)
        {
            max = a[i];
            
            count = count + 1;
        }
    }
    cout << "1) Максимальный элемент - " << max << endl;
    cout << "2) Количество максимальных элементов - " << count << endl;
 
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
14.12.2017, 12:49
Ответы с готовыми решениями:

Путем перестановки строк и столбцов матрицы сделать так, чтобы максимальный элемент был в верхнем левом углу
Матрица, размеры вводятся с клавиатуры. Заполнение рандомом. Путем перестановки строк и столбцов сделать так, чтобы максимальный элемент...

Переместить строки и столбцы матрицы так чтобы максимальный элемент был в левом верхнем углу
Здравствуйте, такая проблема, нужно написать программу в которую пользователь вводит размер массива N на N, и нужно переместить строки и...

Сдвинуть строки циклическим сдвигом вправо так, чтобы на последнем месте был максимальный по модулю элемент
в матрице сдвинуть строки циклическим сдвигом вправо так, что бы на последнем месте был максимальный по модулю элемент.

4
Диссидент
Эксперт C
 Аватар для Байт
27714 / 17332 / 3810
Регистрация: 24.12.2010
Сообщений: 38,978
14.12.2017, 14:02
Лучший ответ Сообщение было отмечено aqroog как решение

Решение

Как-то так
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
int MAX(int a[], int n)
{
    int max = a[0];
    for (int i = 1; i < n; i++) {
        if (a[i] >= max)
            max = a[i];
    }
    for(int i=n-1; i>=0; i--) {
       if (a[i]==max) {
         for(int j=i; j<n-1; j++)
            a[j] = a[j+1];
          n--;
       }
    }
    return n;  // возвращает новую длину массива
}
1
0 / 0 / 0
Регистрация: 14.12.2017
Сообщений: 19
14.12.2017, 14:31  [ТС]
Спасибо большое, но одна проблема.
При вводе 5 элементов массива:
5, 5, 5, 3, 2.

Он удаляет максимальные и сдвигает элементы, но заполняет последние три 2-ками.
Это можно как-то убрать? Или вообще сделать так, что бы новый массив состоял из 2-ух элементов?
Исходя из данного примера.
0
зомбяк
 Аватар для TRam_
1585 / 1219 / 345
Регистрация: 14.05.2017
Сообщений: 3,940
14.12.2017, 14:37
Лучший ответ Сообщение было отмечено aqroog как решение

Решение

aqroog, нужно чтобы
C++
1
case 3: n = MAX(a, n); break;
Тогда массив и будет состоять из двух элементов.

Добавлено через 1 минуту
То есть на самом деле он как состоял из 20 элементов (int a[20]) так и будет состоять, но n изменится в соответствии с числом действительных элементов.
1
0 / 0 / 0
Регистрация: 14.12.2017
Сообщений: 19
14.12.2017, 14:44  [ТС]
Спасибо большое, все работает!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
14.12.2017, 14:44
Помогаю со студенческими работами здесь

Двумерный массив. Измените исходный массив так, чтобы максимальный элемент в каждой строке был заменен на 0
Двумерный массив А (n,m) заполнен случайными целыми числами, находящимися в интервале от 0 до 20. Измените исходный массив так, чтобы...

Переставить строки и столбцы матрицы так, чтобы максимальный элемент был расположен на пересечении k-й строки и k-го столбца
Задана матрица размером n x m. Найти максимальный по модулю элемент матрицы. Переставить строки и столбцы матрицы таким образом, чтобы...

Как сделать так, чтобы каждый элемент ListBoxItem был растянут на всю ширину ListBox
Я бы хотел сделать так, чтобы каждый элемент ListBoxItem был растянут на всю ширину ListBox. Справа на рисунке это ItemsControl, но он не...

Переставить строки и столбцы матрицы так, чтобы максимальный по модулю элемент был расположен на пересечении k-й строки и k-го столбца
Задана матрица размером n*m. Найти максимальный по модулю элемент матрицы. Переставить строки и столбцы матрицы таким образом, чтобы...

Как сделать так, чтобы был доступ к методу вложенного класса, если объявлен только внешний класс
То есть если в классе Class есть вложенный класс innerClass с методом method() была возможна такая вещь: Class class = new Class(); ...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Подключение Box2D v3 к SDL3 для Android: физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
Влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru