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

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

Восстановить пароль Регистрация
Другие темы раздела
C++ В одномерном массива x(15) найти: 1)кол-во элементов, удовлетворяющих условию -0.5<sinх<=0;2)Минимальный элемент http://www.cyberforum.ru/cpp-beginners/thread430160.html
В одномерном массива x(15) найти: 1)кол-во элементов, удовлетворяющих условию -0.5<sinх<=0; 2)Минимальный элемент
C++ Отсортировать список команд Решите пожалуйста задачу, ПОЖАЛУЙСТА! Отсортировать список команд по суммам очков двух туров футбольного чемпионата. Исходные данные или результат или и то и другое должно размещаться в текстовом файле.(с обязательным применением функций) http://www.cyberforum.ru/cpp-beginners/thread430119.html
Помогите сделать указатель на функцию C++
Доброго времени суток помогите пожайлуста в код добавить указатель на функцию. #include <iostream> #include <math.h> using namespace std; const int n = 3, m =3; double l=0, s = 0; size_t i, j;
Файлы.Текстовые файлы C++
Считая t текстовым файлом (файлом типа text), ответить на следующие вопросы: А)Кроме текстовых файлов,файлы какиъ еще типов могут делиться на строки? обезательно ли все строки файла должны быть одинаковой длины?Допустимы ли пустые строки? б)Если при записи в t надо закончить строку то как это сделать?Какие действия вличет выполнение оператора writeln? в)верно ли что из текстового файла...
C++ Кто то читал книгу Давыдов - Visual C++ http://www.cyberforum.ru/cpp-beginners/thread430096.html
Кто читал книгу Давыдов - Visual C++ как она вам? стоит с нее начать изучение Визуального программирования
C++ PE заголовок как вычислить начало первой секции? подробнее

Показать сообщение отдельно
rangerx
1918 / 1527 / 139
Регистрация: 31.05.2009
Сообщений: 2,886
17.01.2012, 22:52     Найти последний максимальный элемент массива и удалить его
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);
 
Текущее время: 20:25. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru