次の方法で共有


hash_set::insert (STL/CLR)

要素を追加します。

    cliext::pair<iterator, bool> insert(value_type val);
    iterator insert(iterator where, value_type val);
    template<typename InIter>
        void insert(InIter first, InIter last);
    void insert(System::Collections::Generic::IEnumerable<value_type>^ right);

パラメーター

  • まず
    挿入する範囲の先頭。

  • last
    挿入する範囲の最後。

  • [right]
    挿入する列挙。

  • val
    挿入するキー値。

  • where
    コンテナー内の挿入位置 (ヒントのみ)。

解説

メンバー関数は、残りのオペランドで指定されたシーケンスを挿入します。

一つ目のメンバー関数は値 valの要素を挿入するようにコミットし X値のペアを返します。X.second が true の場合、 X.first は、新しく挿入された要素を指定します; それ以外の場合は X.first は同等の要素を指定し、それを既に存在します。注文する新しい要素は挿入されません。一つの要素を挿入する場合に使用します。

2 番目のメンバー関数はツール ヒントとして where を使用して値 valの要素、 (パフォーマンスを向上させるため)、および戻りを新しく挿入される要素を指定する反復子挿入します。がわかっている要素の横にある可能性がある一つの要素を挿入する場合に使用します。

3 番目のメンバー関数は、シーケンス [first,last)を挿入します。別のシーケンスからコピーから使用します。または、より多くの要素を挿入するためにも。

4 番目のメンバー関数は rightで指定されたシーケンスを挿入します。列挙子で説明するシーケンスを挿入する場合に使用します。

各要素の挿入は、被制御シーケンスの要素の数の対数に比例した時間がかかります。ただし、挿入位置はカーソルに隣接する要素を指定するツール ヒントを持つ償却定数時に発生する可能性があります。

使用例

// cliext_hash_set_insert.cpp 
// compile with: /clr 
#include <cliext/hash_set> 
 
typedef cliext::hash_set<wchar_t> Myhash_set; 
typedef Myhash_set::pair_iter_bool Pairib; 
int main() 
    { 
    Myhash_set c1; 
    c1.insert(L'a'); 
    c1.insert(L'b'); 
    c1.insert(L'c'); 
 
// display initial contents " a b c" 
    for each (wchar_t elem in c1) 
        System::Console::Write(" {0}", elem); 
    System::Console::WriteLine(); 
 
// insert a single value, unique and duplicate 
    Pairib pair1 = c1.insert(L'x'); 
    System::Console::WriteLine("insert(L'x') = [{0} {1}]", 
        *pair1.first, pair1.second); 
 
    pair1 = c1.insert(L'b'); 
    System::Console::WriteLine("insert(L'b') = [{0} {1}]", 
        *pair1.first, pair1.second); 
 
    for each (wchar_t elem in c1) 
        System::Console::Write(" {0}", elem); 
    System::Console::WriteLine(); 
 
// insert a single value with hint 
    System::Console::WriteLine("insert(begin(), L'y') = {0}", 
        *c1.insert(c1.begin(), L'y')); 
    for each (wchar_t elem in c1) 
        System::Console::Write(" {0}", elem); 
    System::Console::WriteLine(); 
 
// insert an iterator range 
    Myhash_set c2; 
    Myhash_set::iterator it = c1.end(); 
    c2.insert(c1.begin(), --it); 
    for each (wchar_t elem in c2) 
        System::Console::Write(" {0}", elem); 
    System::Console::WriteLine(); 
 
// insert an enumeration 
    Myhash_set c3; 
    c3.insert(   // NOTE: cast is not needed 
        (System::Collections::Generic::IEnumerable<wchar_t>^)%c1); 
    for each (wchar_t elem in c3) 
        System::Console::Write(" {0}", elem); 
    System::Console::WriteLine(); 
    return (0); 
    } 
 
  

必要条件

ヘッダー:<cliext/hash_set>

名前空間: の cliext

参照

関連項目

hash_set (STL/CLR)