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

참고 항목

참조

표준 템플릿 라이브러리