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

Удалить элементы массива расположенные до элемента с максимальным значением

08.12.2021, 12:37. Показов 1207. Ответов 10
Метки c++ (Все метки)

Студворк — интернет-сервис помощи студентам
Думаю,что много лишнего в коде,но хз даже как это задание сделать,максимальное я нашел,но оно и присваивается к выводу и выводится только оно,знаю что совсем немного допистаь надо,но не знаю что... помогите,пожалуйста)


Удалить элементы массива расположенные до элемента с максимальным значением

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
#include <iostream>
#include <math.h>
using namespace std;
int main()
{
    
        int s[10], i, j, n;
 
        {
            cout << "Enter size: ";
            cin >> n;
            for (i = 0; i < n; i++)
            {
                cout << "Enter s[" << i << "]= ";
                cin >> s[i];
            }
            
        }
        {int max;
         max = s[0];
        for (i = 1; i < n; i++)
        {
            if (s[i] > max) max = s[i];
        }
        for (i = 0; i < n; i++)
            if (s[i] < max)
            
                n--; i--;
            }
        for (i = 0; i < n; i++)
            cout << s[i] << " ";
Миниатюры
Удалить элементы массива расположенные до элемента с максимальным значением  
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
08.12.2021, 12:37
Ответы с готовыми решениями:

Удалить элементы расположенные между максимальным и минимальным элементами массива Х. Элементы массива Х вычисляются по формуле Xi=((-1)^i)*((i^2)-3*i), где i=1,2,...,10.
Удалить элементы расположенные между максимальным и минимальным элементами массива Х. Элементы массива Х вычисляются по формуле...

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

Удалить из одномерного массива элементы, расположенные между максимальным и минимальным элементами массива
Люди добрые,помогите человеку,не понимающему массивы! Необходимо решить задачу: &quot;Удалить из одномерного массива элементы,...

10
Нарушитель
10226 / 5657 / 1258
Регистрация: 12.03.2015
Сообщений: 26,193
08.12.2021, 12:47
если входной массив такой:
C++
1
int x[] = {0, 0, 10, 0, 0, 10, 0, 0, 10, 0};
, то что надо удалить, а что оставить? И почему именно так?
0
 Аватар для DeCrinal
64 / 40 / 31
Регистрация: 15.04.2017
Сообщений: 176
08.12.2021, 12:59
Удаление из массива - вещь не очень тривиальная (нужно выделять новую память и переписывать туда все оставшиеся значения)
Но если нужно просто вывести массив, после применения операции, то могу предложить следующий вариант
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
#include<iostream>
using namespace std;
int main(void){
  int s[10],n,i,j;
  int max;
  {
    cout << "Enter size: ";
            cin >> n;
            for (i = 0; i < n; i++)
            {
                cout << "Enter s[" << i << "]= ";
                cin >> s[i];
            }
  }
  {
        max = 0;
        for (i = 1; i < n; i++)
        {
            if (s[i] > s[max]) max = i;
        }
  }
        for (i = max; i < n; i++)
            cout << s[i] << " ";
  return 0;
}
Предлагаю хранить индекс максимального элемента, а не само значение

Добавлено через 1 минуту
Цитата Сообщение от Verevkin Посмотреть сообщение
1
C++
1
int x[] = {0, 0, 10, 0, 0, 10, 0, 0, 10, 0};
, то что надо удалить, а что оставить? И почему именно так?
Ну, здесь, по-моему, все несложно (просто условие немного не раскрыто): до первого встретившегося элемента с максимальным значением
0
Нарушитель
10226 / 5657 / 1258
Регистрация: 12.03.2015
Сообщений: 26,193
08.12.2021, 13:03
Цитата Сообщение от DeCrinal Посмотреть сообщение
до первого встретившегося элемента с максимальным значением
Какие ваши доказательства?
0
 Аватар для DeCrinal
64 / 40 / 31
Регистрация: 15.04.2017
Сообщений: 176
08.12.2021, 13:09
Цитата Сообщение от Verevkin Посмотреть сообщение
Какие ваши доказательства?
За неимением пояснения в задаче - сугубо интуитивные
0
Нарушитель
10226 / 5657 / 1258
Регистрация: 12.03.2015
Сообщений: 26,193
08.12.2021, 13:13
Цитата Сообщение от DeCrinal Посмотреть сообщение
За неимением пояснения в задаче - сугубо интуитивные
Это я чо щас прочитал ваще?
0
Заблокирован
08.12.2021, 13:19
- Пойди купи батон, если будут яйца - купи десяток.
- Программист принес 10 батонов )
0
 Аватар для lemegeton
4903 / 2696 / 921
Регистрация: 29.11.2010
Сообщений: 5,783
08.12.2021, 13:23
Смотря что такое удаление из массива.

Максимальное значение первое попавшееся как в STL.

Без фактического перемещения
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
#include <iostream>
 
const int *max_element(const int *first, const int *last) {
    const int *result = first;
    for (; first != last; ++first) {
        if (*first > *result) {
            result = first;
        }
    }
    return result;
}
 
int main() {
 
    int size;
    std::cin >> size;
 
    int *array = new int[size];
    for (int i = 0; i < size; ++i) {
        std::cin >> array[i];
    }
 
    for (const int *i = array; i != array + size; ++i) {
        std::cout << *i << " ";
    }
    std::cout << std::endl;
 
    // у вас в коде попытка написать примерно так:
    // находим максимальный элемент и выводим элементы, начиная с него
    // без фактического удаления элементов
    const int *maximum = max_element(array, array + size);
    for (const int *i = maximum; i != array + size; ++i) {
        std::cout << *i << " ";
    }
    std::cout << std::endl;
 
    delete[] array;
    return 0;
}


Копирование в новый массив
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
#include <iostream>
 
const int *max_element(const int *first, const int *last) {
    const int *result = first;
    for (; first != last; ++first) {
        if (*first > *result) {
            result = first;
        }
    }
    return result;
}
 
int *copy(const int *first, const int *last, int *destination) {
    while (first != last) {
        *destination++ = *first++;
    }
    return destination;
}
 
int main() {
 
    int size;
    std::cin >> size;
 
    int *array = new int[size];
    for (int i = 0; i < size; ++i) {
        std::cin >> array[i];
    }
 
    for (const int *i = array; i != array + size; ++i) {
        std::cout << *i << " ";
    }
    std::cout << std::endl;
 
    const int *max = max_element(array, array + size);
    std::size_t new_size = size - (max - array);
    int *new_array = new int[new_size];
 
    copy(max, array + size, new_array);
 
    for (const int *i = new_array; i != new_array + new_size; ++i) {
        std::cout << *i << " ";
    }
    std::cout << std::endl;
 
    delete[] array;
    delete[] new_array;
    return 0;
}


С реальным сдвигом влево в том же массиве и вычислением нового конца массива
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
#include <iostream>
 
const int *max_element(const int *first, const int *last) {
    const int *result = first;
    for (; first != last; ++first) {
        if (*first > *result) {
            result = first;
        }
    }
    return result;
}
 
int *shift_left(int *first, int *last, std::size_t n) {
    for (; first < last-n; ++first) {
        *first = *(first + n);
    }
    return last - n;
}
 
int main() {
 
    int size;
    std::cin >> size;
 
    int *array = new int[size];
    for (int i = 0; i < size; ++i) {
        std::cin >> array[i];
    }
 
    for (const int *i = array; i != array + size; ++i) {
        std::cout << *i << " ";
    }
    std::cout << std::endl;
 
    const int *max = max_element(array, array + size);
    int *new_last = shift_left(array, array + size, max - array);
 
    for (const int *i = array; i != new_last; ++i) {
        std::cout << *i << " ";
    }
    std::cout << std::endl;
 
    return 0;
}
0
Нарушитель
10226 / 5657 / 1258
Регистрация: 12.03.2015
Сообщений: 26,193
08.12.2021, 13:24
Цитата Сообщение от SmallEvil Посмотреть сообщение
- Пойди купи батон, если будут яйца - купи десяток.
- Программист принес 10 батонов )
Именно так.
Такие анекдоты на пустом месте не возникают, ибо:
0
0 / 0 / 0
Регистрация: 08.12.2021
Сообщений: 32
08.12.2021, 13:31  [ТС]
зачем нужен void?
0
 Аватар для lemegeton
4903 / 2696 / 921
Регистрация: 29.11.2010
Сообщений: 5,783
08.12.2021, 15:35
Цитата Сообщение от bebra4ka Посмотреть сообщение
зачем нужен void?
А пёс его знает. Я не пользуюсь.

Нужен для того, чтобы указать, что в этом месте тип неприменим.
Например, если указать его возвращаемым типом у функции, то функция ничего возвращать не сможет.

C++
1
2
3
4
5
6
7
8
void doSomething() {
    return; // ok
    // return 1; // ошибка
}
 
int main() {
    auto x = doSomething(); // ошибка
}
Или если сделать указатель на void, то он будет нетипизированным. И к нему нельзя применить, например, dynamic_cast.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
08.12.2021, 15:35
Помогаю со студенческими работами здесь

Удалить из массива положительные элементы, расположенные между максимальным и минимальным
Задание 1. В массиве X определить количество элементов, меньших среднего арифметического значения. Удалить из массива положительные...

Удалить из одномерного массива все элементы расположенные между максимальным и минимальным элементами массива
Удалить из одномерного массива все элементы расположенные между максимальным и минимальным элементами массива

Удалить из массива элемент, расположенный после первого элемента с максимальным значением
Удалить из массива элемент, расположенный после первого элемента с максимальным значением, и элемент после первого элемента с минимальным...

Удалить из массива все положительные элементы, расположенные между максимальным и минимальным
удалить из массива все положительные элементы, расположенные между максимальным и минимальным элементами. при компиляции выдаёт ошибку ...

Удалить все элементы массива расположенные между максимальным и минимальным элементами
в целочисленном массиве X(N) удалить все элементы, расположенные между максимальным и минимальным элеметами. Найти средне арифметическое...


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

Или воспользуйтесь поиском по форуму:
11
Ответ Создать тему
Новые блоги и статьи
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
Фото: Daniel Greenwood
kumehtar 13.11.2025
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru