Как мне использовать remove_if, чтобы удалить элементы в диапазоне двух чисел - PullRequest
1 голос
/ 07 октября 2019

Я создал Class и инициализировал вектор внутри частного поля, затем я инициализировал вектор, используя методы моего Class. Теперь мне нужно удалить элементы в диапазоне двух чисел, которые я должен набрать на клавиатуре

#include <iostream>
#include <vector>
#include <algorithm>

int randomNumber()
{
    return (0 + rand() % 50 - 10);
}

class Array {
vector<int>::iterator p;
public:
    vector<int>array;
    Array(int size)
    {
        array.resize(size);
        generate(array.begin(), array.end(), randomNumber);
    }
    void Print() {
        for (p = array.begin(); p != array.end(); p++) {
            cout << *p << ' ';
        }
        cout << endl;
    }
    void Condense() {
        int a, b;
        cout << "Enter your range: [";  
        cin >> a;
        cin >> b;
        cout << "]" << endl;
        for (p = array.begin(); p != array.end(); p++) {
            if (a < *p < b || a > *p < b) {

            }
        }
    }
};

1 Ответ

2 голосов
/ 07 октября 2019

Вот демонстрационная программа, которая показывает, как вы можете удалить элементы вектора в диапазоне ( a, b ).

#include <iostream>
#include <vector>
#include <tuple>
#include <iterator>
#include <algorithm>

int main() 
{
    std::vector<int> v = { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 };

    for ( const auto &item : v ) std::cout << item << ' ';
    std::cout << '\n';

    int a = 7, b = 2;

    std::tie( a, b ) = std::minmax( { a, b } );

    auto inside_range = [&]( const auto &item )
    {
        return a < item && item < b;
    };

    v.erase( std::remove_if( std::begin( v ), std::end( v ), inside_range ),
             std::end( v ) );

    for ( const auto &item : v ) std::cout << item << ' ';
    std::cout << '\n';

    return 0;
}

Его вывод

0 1 2 3 4 5 6 7 8 9 
0 1 2 7 8 9 

Вместо использования std:: minmax и std :: tie для порядка a и b, вы можете просто написать условие как

    auto inside_range = [&]( const auto &item )
    {
        return a < item && item < b || b < item && item < a;
    };

Что касается вашего кода, то условие в операторе if

if ( a < *p < b || a > *p < b) {

имеет видневерно, Вы имеете в виду

if (a < *p && *p < b || b < *p && *p < a ) {
...