在 C++ 中的数组中移动元素
本文将介绍几种在 C++ 中如何移动数组中的元素的方法。
使用 std::rotate
算法在 C++ 中移动数组中的元素
std::rotate
函数是 C++ 算法库的一部分,可以使用 <algorithm>
头文件导入。这个算法将数组元素旋转到左侧。它需要三个迭代器类型的参数,其中第二个参数指定需要作为新构造的范围的第一个元素。同时,第一个和第三个元素是源范围的起始和结束位置的指定符。
注意,std::rotate
可以利用 rbegin
/rend
迭代器将元素移到右边。在下面的例子中,函数在具有 10 个整数的 std::vector
对象上调用,并演示了两个方向的操作。
#include <iostream>
#include <vector>
#include <array>
#include <algorithm>
using std::cout; using std::vector;
using std::array; using std::rotate;
using std::endl;
template<typename T>
void printElements(T &v)
{
cout << "[ ";
for (const auto &item : v) {
cout << item << ", ";
}
cout << "\b\b ]" << endl;
}
int main()
{
vector<int> vec = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
printElements(vec);
rotate(vec.begin(), vec.begin() + 3, vec.end());
printElements(vec);
rotate(vec.rbegin(), vec.rbegin() + 3, vec.rend());
exit(EXIT_SUCCESS);
}
输出:
[ 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 ]
[ 4, 5, 6, 7, 8, 9, 10, 1, 2, 3 ]
使用自定义封装函数 std::rotate
在 C++ 中移动数组中的元素
或者,我们可以实现封装函数来封装 std::rotate
算法,并要求用户只传递两个参数-要旋转的数组对象和代表要移动的位置数的整数。我们也可以将传递的整数的符号表示为旋转操作的方向。
在这个自定义函数中,我们任意选择正数表示右旋,负数表示左旋。
需要注意的是,这个 rotateArrayElements
函数模板既可以在固定数组对象上工作,也可以在用 C++ 标准库容器构建的动态数组对象上工作。
#include <iostream>
#include <vector>
#include <array>
#include <algorithm>
using std::cout; using std::vector;
using std::array; using std::rotate;
using std::endl;
template<typename T>
void printElements(T &v)
{
cout << "[ ";
for (const auto &item : v) {
cout << item << ", ";
}
cout << "\b\b ]" << endl;
}
template<typename T>
int rotateArrayElements(T &v, int dir)
{
if (dir > 0) {
rotate(v.rbegin(), v.rbegin() + dir, v.rend());
return 0;
} else if (dir < 0) {
rotate(v.begin(), v.begin() + abs(dir), v.end());
return 0;
} else {
return 1;
}
}
int main()
{
array<int, 10> arr = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
vector<int> vec = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
rotateArrayElements(arr, 3);
printElements(arr);
rotateArrayElements(vec, -3);
printElements(vec);
exit(EXIT_SUCCESS);
}
输出:
[ 8, 9, 10, 1, 2, 3, 4, 5, 6, 7 ]
[ 4, 5, 6, 7, 8, 9, 10, 1, 2, 3 ]
使用 std::rotate_copy
算法在 C++ 中移动数组中的元素
std::rotate_copy
算法实现了与 std::rotate
相同的操作,只是前者将旋转后的数组元素复制到另一个用附加函数参数指定的范围。
首先,我们需要声明新的范围,在这种情况下,选择 std::vector
类型,构造函数取源 vector
的大小。
然后我们可以调用 rotate_copy
函数,其参数与我们为 std::rotate
指定的参数相同,第四个迭代器表示目标 vector
的开始。
请注意,下面的例子只演示了数组元素的左旋。
#include <iostream>
#include <vector>
#include <array>
#include <algorithm>
using std::cout; using std::vector;
using std::array; using std::rotate;
using std::endl; using std::rotate_copy;
template<typename T>
void printElements(T &v)
{
cout << "[ ";
for (const auto &item : v) {
cout << item << ", ";
}
cout << "\b\b ]" << endl;
}
int main()
{
vector<int> vec1 = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
printElements(vec1);
vector<int> vec2(vec1.size());
rotate_copy(vec1.begin(), vec1.begin() + 3, vec1.end(), vec2.begin());
printElements(vec2);
exit(EXIT_SUCCESS);
}
[ 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 ]
[ 4, 5, 6, 7, 8, 9, 10, 1, 2, 3 ]
相关文章
C 中移位运算符的类型
发布时间:2023/05/06 浏览次数:146 分类:C语言
-
本文介绍如何在C中使用右移算术运算符,右移一个位置将每位向右移动一位。 >> 运算符是移位无符号值时的逻辑移位。 >> 运算符是一个算术
在 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++ 字符串是否是数字。在我们深入研究之前,需要注意的是,以下方法只与单字节字符串和十进制整数兼容。