다음을 통해 공유


set::insert

요소 또는 요소 범위 집합에 삽입합니다.

pair<iterator, bool> insert(
   const value_type& _Val
);
iterator insert(
   iterator _Where,
   const value_type& _Val
);
template<class InputIterator>
   void insert(
      InputIterator _First,
      InputIterator _Last
);
template<class ValTy>
    pair<iterator, bool> insert(
        ValTy&& _Val
);
template<class ValTy>
    iterator insert(
        const_iterator _Where,
        ValTy&& _Val
);

매개 변수

Parameter

설명

_Val

해당 요소 또는 더 일반적으로 키 변환과 정렬 된 요소 집합에 이미 포함 되어 있지 않으면 집합에 삽입할 요소의 값입니다.

_Where

올바른 삽입 지점에 대 한 검색을 시작할 수 있습니다.(삽입 발생할 수 있습니다 로그 시간 대신 amortized 상수 시간에 바로 삽입 지점 다음에 오는 경우 _Where.)

_First

집합에서 복사할 첫 번째 요소의 위치입니다.

_Last

집합에서 복사 하는 마지막 요소는 위치입니다.

반환 값

첫 번째 삽입 멤버 함수 반환 부울 요소를 반환 하는 쌍 true 에 삽입 된 경우 및 거짓 집합 키 같은 값의 순서에 있어 반복기 요소가 반환 주소가 있는 요소가 이미 있는 경우 또는 새 요소가 삽입 된 위치에 요소가 이미 포함 된 경우.

두 번째 삽입 멤버 함수 새 요소 집합에 삽입 된 위치를 가리키는 반복기를 반환 합니다.

마지막으로 두 명의 멤버 함수를 제외 하 고 처음 두와 똑같이 동작 val 삽입 된 값을 생성 하는 데 사용 됩니다.

설명

셋째 멤버 함수 집합 반복기의 범위에 의해 주소가 지정 된 각 요소에 해당 시퀀스의 요소 값 삽입 [_First, _Last) 지정 된 집합입니다.

예제

// set_insert.cpp
// compile with: /EHsc
#include <set>
#include <iostream>
#include <string>

int main( )
{
   using namespace std;
   set <int>::iterator s1_pIter, s2_pIter;

   set <int, less<int> > s1, s2;
   s1.insert( 10 );
   s1.insert( 20 );
   s1.insert( 30 );
   s1.insert( 40 );

   cout << "The original s1 =";
   for ( s1_pIter = s1.begin( ); s1_pIter != s1.end( ); s1_pIter++ )
      cout << " " << *s1_pIter;
   cout << "." << endl;

   pair< set<int>::iterator, bool > pr;
   pr = s1.insert( 10 );

   if(pr.second == true)   
   {
      cout << "The element 10 was inserted in s1 successfully."
           << endl;
   }
   else   
   {
      cout << "The element 10 already exists in s1 and"
           << " *( pr.first ) = " << *( pr.first ) << "." << endl;
   }

   s1.insert( --s1.end( ), 50 );

   cout << "After the insertions, s1 =";
   for ( s1_pIter = s1.begin( ); s1_pIter != s1.end( ); s1_pIter++ )
      cout << " " << *s1_pIter;
   cout << "." << endl;

   s2.insert( 100 );
   s2.insert( ++s1.begin( ), --s1.end( ) );

   cout << "s2 =";
   for ( s2_pIter = s2.begin( ); s2_pIter != s2.end( ); s2_pIter++ )
      cout << " " << *s2_pIter;
   cout << "." << endl;

   // Construct by moving
   set<string> s3, s4;
   string str1("a"), str2("b");

   s3.insert(move(str1));
   cout << "After the move insertion, s3 contains: "
      << *s3.begin() << endl;

   s4.insert(s4.begin(), move(str2));
   cout << "After the move insertion, s4 contains: "
      << *s4.begin() << endl;
 }
  
  
  
  
  

요구 사항

헤더: <set>

네임 스페이스: std

참고 항목

참조

set Class

표준 템플릿 라이브러리