Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.73/11: Рейтинг темы: голосов - 11, средняя оценка - 4.73
0 / 0 / 0
Регистрация: 15.11.2011
Сообщений: 24
1

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

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

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

Заранее спасибо!
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
17.01.2012, 20:33
Ответы с готовыми решениями:

Найти максимальный элемент массива и вывести последний четный элемент
Короче нужно чтобы програма нашла максимальный елемент масива и выводила на екран последное четное...

Найти первый максимальный элемент массива и последний минимальный
Здравствуйте. Может можно при помощи стандартных методов найти первый максимальный и последний...

Найти последний нулевой элемент в последовательности Х1,Х2...Хn и удалить его из ряда
1.Найти последний нулевой элемент в последовательности Х1,Х2...Хn и удалить его из ряда.

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

6
82 / 82 / 24
Регистрация: 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;
}
1
0 / 0 / 0
Регистрация: 15.11.2011
Сообщений: 24
17.01.2012, 21:24  [ТС] 3
А можешь написать как все это будет выглядить в фри и борланд паскале?
0
2551 / 1316 / 177
Регистрация: 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/... c0b05da37e

Добавлено через 33 секунды
Цитата Сообщение от Андрей М Посмотреть сообщение
А можешь написать как все это будет выглядить в фри и борланд паскале?
Вы, батенька, разделом ошиблись. Это Си/С++
0
0 / 0 / 0
Регистрация: 15.11.2011
Сообщений: 24
17.01.2012, 21:30  [ТС] 5
спасибо
0
82 / 82 / 24
Регистрация: 30.09.2011
Сообщений: 404
Записей в блоге: 6
17.01.2012, 21:33 6
ну если вы знаете хоть немного с++ то будет выглядеть также, тоесть забивается массив и осуществляется поиск, ну и т.д.
0
1992 / 1592 / 488
Регистрация: 31.05.2009
Сообщений: 2,980
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);
3
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
17.01.2012, 22:52

Заказываю контрольные, курсовые, дипломные и любые другие студенческие работы здесь.

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

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

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

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


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

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

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