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

Найти последний максимальный элемент массива и удалить его - C++

Восстановить пароль Регистрация
 
Андрей М
0 / 0 / 0
Регистрация: 15.11.2011
Сообщений: 24
17.01.2012, 20:33     Найти последний максимальный элемент массива и удалить его #1
Помогите решить 3 легких задачи!
1)Найти послед максимальный и удалить его.
2)Найти первый минимальный и удалить его.
3)Первый четный кратный 3 и удалить его.
4)Удалить все элементы равные 0.

Заранее спасибо!
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
17.01.2012, 20:33     Найти последний максимальный элемент массива и удалить его
Посмотрите здесь:

C++ Определить последний отрицательный максимальный элемент и его позицию в массиве
C++ Найти максимальный элемент массива и его номер
Найти максимальный элемент массива и вывести его на экран C++
C++ Найти максимальный элемент в массиве и удалить его
Найти максимальный элемент массива из его элементов с нечетными номерами C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
LostCoast
82 / 82 / 5
Регистрация: 30.09.2011
Сообщений: 404
Записей в блоге: 6
17.01.2012, 21:21     Найти последний максимальный элемент массива и удалить его #2
Сообщение было отмечено автором темы, экспертом или модератором как ответ
1)Найти послед максимальный и удалить его
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;
const int N = 5;
 
int main() 
{
    int a[N];
    int max, m;
    for (int i = 0; i < N; i++) {
        cout << "vvedite a[" << i << "]= ";
        cin >> a[i];
    }
    max = 0;
    for (int i = 0; i < N; i++) 
        if (max < a[i]) {
            max = a[i];
            m = i;
        }
    for (int i = m; i < N; i++) 
        a[i] = a[i + 1];
    for (int i = 0; i < N - 1; i++)
        cout << "a = " << a[i] << endl;
    cout << "max = " << max << endl;
    return 0;
}
Андрей М
0 / 0 / 0
Регистрация: 15.11.2011
Сообщений: 24
17.01.2012, 21:24  [ТС]     Найти последний максимальный элемент массива и удалить его #3
А можешь написать как все это будет выглядить в фри и борланд паскале?
soon
 Аватар для soon
2536 / 1301 / 81
Регистрация: 09.05.2011
Сообщений: 3,086
Записей в блоге: 1
17.01.2012, 21:29     Найти последний максимальный элемент массива и удалить его #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
#include <vector>
#include <iostream>
#include <cstdlib>
#include <ctime>
#include <iterator>
#include <algorithm>
 
int main()
{
    std::srand(std::time(nullptr));
    std::vector<int> v(10);
    generate(v.begin(), v.end(), [] { return std::rand() % 11 - 5; });
    std::copy(v.begin(), v.end(), std::ostream_iterator<int>(std::cout, " "));
    std::cout << std::endl;
    v.erase(v.begin() + (v.rend() - std::max_element(v.rbegin(), v.rend()) - 1));
    v.erase(std::min_element(v.begin(), v.end()));
    auto it = std::find_if(v.begin(), v.end(), 
              [](int num) -> bool
              {
                  return !(num % 6);
              });
    if(it != v.end())
        v.erase(it);
    auto end = std::remove(v.begin(), v.end(), 0);
    std::copy(v.begin(), end, std::ostream_iterator<int>(std::cout, " "));
    std::cout << std::endl;
    return 0;
}
http://liveworkspace.org/code/85f380...591dc0b05da37e

Добавлено через 33 секунды
Цитата Сообщение от Андрей М Посмотреть сообщение
А можешь написать как все это будет выглядить в фри и борланд паскале?
Вы, батенька, разделом ошиблись. Это Си/С++
Андрей М
0 / 0 / 0
Регистрация: 15.11.2011
Сообщений: 24
17.01.2012, 21:30  [ТС]     Найти последний максимальный элемент массива и удалить его #5
спасибо
LostCoast
82 / 82 / 5
Регистрация: 30.09.2011
Сообщений: 404
Записей в блоге: 6
17.01.2012, 21:33     Найти последний максимальный элемент массива и удалить его #6
ну если вы знаете хоть немного с++ то будет выглядеть также, тоесть забивается массив и осуществляется поиск, ну и т.д.
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
17.01.2012, 22:52     Найти последний максимальный элемент массива и удалить его
Еще ссылки по теме:

C++ Среди элементов массива найти максимальный элемент и его номер
Найти максимальный элемент массива и поставить его первым C++
Найти в стеке самый максимальный элемент и удалить его C++

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

Или воспользуйтесь поиском по форуму:
rangerx
1908 / 1517 / 139
Регистрация: 31.05.2009
Сообщений: 2,876
17.01.2012, 22:52     Найти последний максимальный элемент массива и удалить его #7
Сообщение было отмечено автором темы, экспертом или модератором как ответ
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
#include <iostream>
#include <cstddef>
 
//------------------
 
void println_arr(const int a[], size_t size)
{
    for(size_t i = 0; i < size; ++i)
        std::cout << a[i] << " ";
    std::cout << std::endl;
}
 
//------------------
 
void remove_at_index(int a[], size_t* size, size_t idx)
{
    for(; idx < *size; ++idx)
        a[idx] = a[idx + 1];
    --*size;
}
 
//------------------
 
void remove_all(int a[], size_t* size, int val)
{
    size_t j = 0;
    for(size_t i = 0; i != *size; ++i)
        if(a[i] != val) a[j++] = a[i];
    *size = j;
}
 
//------------------
 
int main()
{
    const size_t capacity = 10;
    int a[capacity];
 
    size_t size = capacity;
    for(size_t i = 0; i < size; ++i)
    {
        std::cout << "[" << i+1 << "\\" << size << "]: ";
        std::cin >> a[i];
    }
    println_arr(a, size);
 
    //----------- 1
    size_t imax = 0;
    for(size_t i = 1; i < size; ++i)
        if(a[i] >= a[imax]) imax = i;
    remove_at_index(a, &size, imax);
    println_arr(a, size);
 
    //----------- 2
    size_t imin = 0;
    for(size_t i = 1; i < size; ++i)
        if(a[i] < a[imin]) imin = i;
    remove_at_index(a, &size, imin);
    println_arr(a, size);
 
    //----------- 3
    for(size_t i = 1; i < size; i+= 2)
    {
        if(a[i] % 3 == 0)
        {
            remove_at_index(a, &size, i);
            break;
        }
    }
    println_arr(a, size);
 
    //----------- 4
    remove_all(a, &size, 0);
    println_arr(a, size);
}
Цитата Сообщение от soon Посмотреть сообщение
C++
1
v.erase(v.begin() + (v.rend() - std::max_element(v.rbegin(), v.rend()) - 1));
C++
1
v.erase(std::max_element(v.rbegin(), v.rend()).base() - 1);
Yandex
Объявления
17.01.2012, 22:52     Найти последний максимальный элемент массива и удалить его
Ответ Создать тему
Опции темы

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