swap_ranges
요소를 다른 동일한 크기의 요소 범위를 범위를 교환합니다.
template<class ForwardIterator1, class ForwardIterator2>
ForwardIterator2 swap_ranges(
ForwardIterator1 _First1,
ForwardIterator1 _Last1,
ForwardIterator2 _First2
);
매개 변수
_First1
첫 번째 요소를 교환 하는 범위의 첫 번째 위치로 가리키는 정방향 반복기입니다._Last1
한 요소를 교환 하는 첫 번째 범위의 마지막 위치를 가리키는 정방향 반복기가._First2
요소를 교환 하는 두 번째 범위의 첫 번째 위치를 가리키는 정방향 반복기가.
반환 값
한 요소를 교환 하는 두 번째 범위의 마지막 위치를 가리키는 정방향 반복기가.
설명
참조 하는 범위의 유효 해야 합니다. 모든 포인터는 dereferenceable 이어야 하며 각 시퀀스에서 마지막 위치에서 첫 번째 도달할 수 여 증분 합니다.두 번째 범위 첫 번째 범위는 클 수 있습니다.
복잡도를 선형이 _Last1 - _First1 교체를 수행 합니다.유형이 같은 컨테이너에서 요소 되 고 바뀌었는지 경우,이 swap 멤버 함수를 해당 컨테이너에서 사용 해야 합니다, 멤버 함수는 일반적으로 상수 복잡성 있기 때문에.
예제
// alg_swap_ranges.cpp
// compile with: /EHsc
#include <vector>
#include <deque>
#include <algorithm>
#include <iostream>
int main( )
{
using namespace std;
vector <int> v1;
deque <int> d1;
vector <int>::iterator v1Iter1;
deque<int>::iterator d1Iter1;
int i;
for ( i = 0 ; i <= 5 ; i++ )
{
v1.push_back( i );
}
int ii;
for ( ii =4 ; ii <= 9 ; ii++ )
{
d1.push_back( 6 );
}
cout << "Vector v1 is ( " ;
for ( v1Iter1 = v1.begin( ) ; v1Iter1 != v1.end( ) ;v1Iter1 ++ )
cout << *v1Iter1 << " ";
cout << ")." << endl;
cout << "Deque d1 is ( " ;
for ( d1Iter1 = d1.begin( ) ; d1Iter1 != d1.end( ) ;d1Iter1 ++ )
cout << *d1Iter1 << " ";
cout << ")." << endl;
swap_ranges ( v1.begin ( ) , v1.end ( ) , d1.begin ( ) );
cout << "After the swap_range, vector v1 is ( " ;
for ( v1Iter1 = v1.begin( ) ; v1Iter1 != v1.end( ) ;v1Iter1 ++ )
cout << *v1Iter1 << " ";
cout << ")." << endl;
cout << "After the swap_range deque d1 is ( " ;
for ( d1Iter1 = d1.begin( ) ; d1Iter1 != d1.end( ) ;d1Iter1 ++ )
cout << *d1Iter1 << " ";
cout << ")." << endl;
}
요구 사항
헤더: <algorithm>
네임 스페이스: std