从大于n的数组中删除所有元素

时间:2014-12-17 07:43:38

标签: c++ arrays remove-if

我是编程的初学者。有些东西给我代码带来麻烦。假设,我有一个数组。

int Array[] = {3,6,9,5,10,21,3,25,14,12,32,41,3,24,15,26,7,8,11,4};

我想删除所有大于9的元素。我该怎么做?

3 个答案:

答案 0 :(得分:8)

如果使用矢量,则可以执行此操作。首先用数组初始化向量。然后使用remove_if()函数。希望这会有所帮助。

#include <algorithm>
#include <vector>

int main()
{
int Array[] = {3,6,9,5,10,21,3,25,14,12,32,41,3,24,15,26,7,8,11,4};

vector<int> V(Array, Array+20);
vector<int> :: iterator it;

it = remove_if(V.begin(), V.end(), bind2nd(greater<int>(), 9));


V.erase (it, V.end());  // This is your required vector if you wish to use vector

}

答案 1 :(得分:5)

您无法从阵列中删除项目,因为它们的大小已固定。

如果您使用std::vector,那么解决方案将如下所示:

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

  using namespace std;

  int main()
  {
     std::vector<int> Array = {3,6,9,5,10,21,3,25,14,12,32,41,3,24,15,26,7,8,11,4};

     Array.erase(remove_if(Array.begin(), Array.end(), [](int n) { return n > 9; }),
                 Array.end());
     copy(Array.begin(), Array.end(), ostream_iterator<int>(cout, " "));

  }

实例:http://ideone.com/UjdJ5h

如果您想坚持使用数组,但是标记大于10的项目,则可以使用相同的算法std::remove_if

  #include <algorithm>
  #include <iostream>
  #include <iterator>

  using namespace std;

  int main()
  {
     int Array[] = {3,6,9,5,10,21,3,25,14,12,32,41,3,24,15,26,7,8,11,4};
     int *overwrite_start = remove_if(std::begin(Array), std::end(Array), [](int n){ return n>9; });
     fill(overwrite_start, std::end(Array), -1);
     copy(std::begin(Array), std::end(Array), ostream_iterator<int>(cout, " "));
  }

上面将“擦除”项目移动到数组的末尾,并用-1标记它们。

实例:http://ideone.com/7rwaXy

请注意STL算法函数的两个示例中的用法。数组的第二个示例使用相同的remove_if算法函数。 remove_if返回“已删除”数据的开头,因为remove_if实际上没有删除,但会将数据移动到序列的末尾。

答案 2 :(得分:1)

我尝试不使用矢量的交换概念

int Array[] = {3,6,9,5,10,21,3,25,14,12,32,41,3,24,15,26,7,8,11,4};
int n;
int arr_len = sizeof(Array)/sizeof(int);
void print_array_value() {
int i;
cout << "\n";
for (i = 0; i < arr_len; i++) {
    cout << Array[i] << ", ";
}
cout << " : " << arr_len << "\n";
}
void swap_array_value(int start) {
int i;
for ( ; (start+1) < arr_len; start++) {
    Array[start] = Array[start+1];
}
}
void remove_array_value() {
int i;
for (i = 0; i < arr_len; i++) {
    if (Array[i] > n) {
        swap_array_value(i);
        arr_len--;
        i--;
    }
}
}
void main () {
clrscr();
cout << "Enter the N value : ";
cin >> n;
print_array_value();
remove_array_value();
print_array_value();
cout << "Array Length : " << arr_len;
getch();
}