在 C++ 中从数组中删除元素
本文将介绍几种在 C++ 中如何从数组中删除元素的方法。
从 C++ 中使用 std::to_array
和 std::remove
函数从数组中删除元素
数组可以在 C++ 中定义为定长或动态数组,并且它们都需要使用不同的方法来删除元素。在此示例中,我们考虑内置的 C 样式固定数组,因为这些数组通常由数字程序操纵以提高效率。
我们将声明一个 int
数组,并删除元素值 2
,该元素值在该数组中出现两次。std::remove
是算法库的一部分,它删除指定范围内给定元素的所有实例。
尽管起初,我们使用 std::to_array
函数将 arr
对象转换为 std::array
容器,以便安全地与 std::remove
方法一起使用。后一种算法返回范围的新末端的迭代器,这意味着所得的数组
对象仍包含 10
个元素,我们需要将其复制到新位置。由于原始对象是 C 样式的数组,因此我们为 8 个元素的 int
数组分配了新的动态内存,并使用了 std::memmove
函数从 array
对象中复制了内容。请注意,我们使用 std::distance
函数计算了 8
值。
#include <iostream>
#include <array>
#include <iterator>
#include <cstring>
using std::cout; using std::endl;
using std::array; using std::remove;
int main() {
int arr[10] = {1, 1, 1, 2, 2, 6, 7, 8, 9, 10};
int elem_to_remove = 2;
cout << "| ";
for (const auto &item : arr) {
cout << item << " | ";
}
cout << endl;
auto tmp = std::to_array(arr);
auto len = std::distance(tmp.begin(), (tmp.begin(), tmp.end(), elem_to_remove));
auto new_arr = new int[len];
std::memmove(new_arr, tmp.data(), len * sizeof(int));
cout << "| ";
for (int i = 0; i < len; ++i) {
cout << new_arr[i] << " | ";
}
cout << endl;
delete [] new_arr;
return EXIT_SUCCESS;
}
输出:
| 1 | 1 | 1 | 2 | 2 | 6 | 7 | 8 | 9 | 10 |
| 1 | 1 | 1 | 6 | 7 | 8 | 9 | 10 |
使用 std::erase
和 std::remove
函数从 C++ 中的数组中删除元素
当给定数组的类型为 std::vector
时,会发生此问题的另一种情况。这次,我们有了动态数组特性,使用内置函数进行元素操作更加灵活。
在下面的示例代码中,我们将使用擦除-删除
惯用语并删除范围中给定元素的所有出现。请注意,std::erase
需要两个迭代器来表示要删除的范围。因此,它需要 std::remove
算法的返回值来指定起点。请注意,如果仅调用 std::remove
方法,则 arr2
对象的元素将是 - {1, 1, 1, 6, 7, 8, 9, 10, 9, 10}
。
#include <iostream>
#include <iterator>
#include <vector>
using std::cout; using std::endl;
using std::vector; using std::remove;
int main() {
vector<int>arr2 = {1, 1, 1, 2, 2, 6, 7, 8, 9, 10};
int elem_to_remove = 2;
cout << "| ";
for (const auto &item : arr2) {
cout << item << " | ";
}
cout << endl;
arr2.erase(std::remove(arr2.begin(), arr2.end(), elem_to_remove), arr2.end());
cout << "| ";
for (const auto &item : arr2) {
cout << item << " | ";
}
cout << endl;
return EXIT_SUCCESS;
}
输出:
| 1 | 1 | 1 | 2 | 2 | 6 | 7 | 8 | 9 | 10 |
| 1 | 1 | 1 | 6 | 7 | 8 | 9 | 10 |
相关文章
在 C++ 中通过掷骰子生成随机值
发布时间:2023/04/09 浏览次数:169 分类:C++
-
本文解释了如何使用时间因子方法和模拟 C++ 中的掷骰子的任意数方法生成随机数。了解它是如何工作的以及它包含哪些缺点。提供了一个 C++ 程序来演示伪数生成器。
在 C++ 中使用模板的链表
发布时间:2023/04/09 浏览次数:158 分类:C++
-
本文解释了使用模板在 C++ 中创建链表所涉及的各个步骤。工作程序演示了一个链表,该链表使用模板来避免在创建新变量时声明数据类型的需要。
在 C++ 中添加定时延迟
发布时间:2023/04/09 浏览次数:142 分类:C++
-
本教程将为你提供有关在 C++ 程序中添加定时延迟的简要指南。这可以使用 C++ 库为我们提供的一些函数以多种方式完成。
在 C++ 中创建查找表
发布时间:2023/04/09 浏览次数:155 分类:C++
-
本文重点介绍如何创建查找表及其在不同场景中的用途。提供了三个代码示例以使理解更容易,并附有代码片段以详细了解代码。
如何在 C++ 中把字符串转换为小写
发布时间:2023/04/09 浏览次数:63 分类:C++
-
介绍了如何将 C++ std::string 转换为小写的方法。当我们在考虑 C++ 中的字符串转换方法时,首先要问自己的是我的输入字符串有什么样的编码
如何在 C++ 中确定一个字符串是否是数字
发布时间:2023/04/09 浏览次数:163 分类:C++
-
本文介绍了如何检查给定的 C++ 字符串是否是数字。在我们深入研究之前,需要注意的是,以下方法只与单字节字符串和十进制整数兼容。
如何在 c++ 中查找字符串中的子字符串
发布时间:2023/04/09 浏览次数:65 分类:C++
-
本文介绍了在 C++ 中检查一个字符串是否包含子字符串的多种方法。使用 find 方法在 C++ 中查找字符串中的子字符串
如何在 C++ 中把字符串转换为 Char 数组
发布时间:2023/04/09 浏览次数:107 分类:C++
-
本文介绍了在 C++ 中把字符串转换为 char 数组的多种方法。使用 std::basic_string::c_str 方法将字符串转换为 char 数组