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

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

Войти
Регистрация
Восстановить пароль
 
Андрей М
0 / 0 / 0
Регистрация: 15.11.2011
Сообщений: 24
#1

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

17.01.2012, 20:33. Просмотров 461. Ответов 6
Метки нет (Все метки)

Помогите решить 3 легких задачи!
1)Найти послед максимальный и удалить его.
2)Найти первый минимальный и удалить его.
3)Первый четный кратный 3 и удалить его.
4)Удалить все элементы равные 0.

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

Найти максимальный элемент массива и вывести последний четный элемент - C++
Короче нужно чтобы програма нашла максимальный елемент масива и выводила на екран последное четное число масива #include<iostream> ...

Найти максимальный элемент в массиве и удалить его - C++
У нас одномерный массив. Количество элементов и сами элементы вводятся с клавиатуры. нужно найти максимальный элемент в этом массиве и...

Найти и удалить последний четный элемент динамического массива - C++
Требуется: 1) Ввести дин. массив, ввод осуществляется пока эл. массива не превышает суммы предыдущих 2) Найти и удалить последний...

Найти в стеке самый максимальный элемент и удалить его - C++
Доброго времени суток. У меня, к примеру, есть стек. В нем введено несколько элементов, допустим 4. Как найти в стеке самый максимальный и...

Найти максимальный элемент массива и его номер - C++
Составить программу записи в массив В номеров четных элементов массива А. Дан одномерный массив состоящий из различных целых чисел. Найти...

Найти максимальный элемент массива и его номер - C++
задан массив n элемнтов,найти max элемент массиваи его номер

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
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
2540 / 1305 / 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
ну если вы знаете хоть немного с++ то будет выглядеть также, тоесть забивается массив и осуществляется поиск, ну и т.д.
rangerx
1933 / 1542 / 141
Регистрация: 31.05.2009
Сообщений: 2,912
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);
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
17.01.2012, 22:52
Привет! Вот еще темы с ответами:

Найти максимальный элемент массива и вывести его на экран - C++
Программа заполняет массив из 12 целых чисел случайными числами в диапазоне от -3 до 38. Программа находит максимальный элемент массива и...

Найти максимальный элемент массива и поставить его первым - C++
Доброго времени суток! Очень нуждаюсь в вашей помощи, помогите, пожалуйста, решить задачу: Найти максимальный по модулю элемент...

Найти максимальный элемент массива и его порядковый номер. - C++
17.Дан массив А(4). Найти максимальный элемент массива и его порядковый номер.

Определить последний отрицательный максимальный элемент и его позицию в массиве - C++
мальчики помогите пожалуйста решить задачи 1)Для заданного двумерного массива из n строк и m столбцов: a.)Определить последний...


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

Или воспользуйтесь поиском по форуму:
Yandex
Объявления
17.01.2012, 22:52
Ответ Создать тему
Опции темы

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