copy_backward是C++ STL 算法组件中的其中一个算法,其作用是将指定序列局部元素逆向复制到另一个序列中。
例子代码:
#include <iostream>
#include <vector>
#include <deque>
using namespace std;
void main()
{
//创建两个容器 和 两个数组
vector<int> v = { 1,2,3,4,5,6,7,8,9,10 };
vector<int> v2(10);
vector<int>::iterator vi;//迭代器
int arr[10] = { 11,12,13,14,15,16,17,18,19,20 };
cout << "执行copy算法前:\n";
// 输出 v
cout << "容器 v: ";
for (vi = v.begin(); vi < v.end(); vi++) { cout << *vi << "\t"; }
cout << endl;
// 输出 v2
cout << "容器 v2: ";
for (vi = v2.begin(); vi < v2.end(); vi++) { cout << *vi << "\t"; }
cout << endl;
// 输出 arr
cout << "数组 arr: ";
for (int i = 0; i<10; i++) { cout << arr[i] << "\t"; }
cout << endl;
cout << "\n执行 copy_backward 算法后:\n";
// STL copy_backward算法
// 1、拷贝源是容器,拷贝目标是容器
copy_backward(v.begin(), v.begin()+5, v2.end());
// 输出 v2
cout << "容器 v2: ";
for (vi = v2.begin(); vi < v2.end(); vi++) { cout << *vi << "\t"; }
cout << endl << endl;
// 2、拷贝源是数组,拷贝目标是容器
copy_backward(arr, arr + 5, v2.end()-1);
// 输出 v2
cout << "容器 v2: ";
for (vi = v2.begin(); vi < v2.end(); vi++) { cout << *vi << "\t"; }
cout << endl << endl;
// 3、拷贝源是容器,拷贝目标是同一个容器
copy_backward(v.begin(), v.begin() + 7, v.end());
// 输出 v2
cout << "容器 v : ";
for (vi = v.begin(); vi < v.end(); vi++) { cout << *vi << "\t"; }
cout << endl ;
}
运行结果:
copy_backward的参数形式:copy_backward(拷贝内容的起始位置,拷贝内容的结束位置,拷贝目标的拷贝起始位置)
copy_backward 的作用:
将要拷贝的内容从最后一个元素开始拷贝,从拷贝目标的拷贝起始位置开始拷贝,拷贝内容的最后一个元素拷贝到拷贝目标的拷贝起始位置;
拷贝内容的倒数第二个元素拷贝到拷贝目标的拷贝起始位置的前一位;
拷贝内容的倒数第三个元素拷贝到拷贝目标的拷贝起始位置的前两位
……
拷贝内容的倒数第 N 个元素拷贝到拷贝目标的拷贝起始位置的前 N 位。
注意事项:
1、拷贝的内容元素的个数,不能大于拷贝目标的拷贝起始位置到拷贝目标的起始位置之间的容量,否则会溢出,程序报错,如果不进行处理程序抛出的错,程序终止。
2、拷贝源可以是数组,但拷贝目标不能是数组。
以上。
感谢您的浏览。