インデックスによる std::vector からの要素の削除
プログラミングにおける一般的なタスクの 1 つは、ベクターなどのコンテナから要素を削除することです。 std::vector は、要素の効率的な挿入と削除を可能にする C の動的配列です。インデックスによる要素の削除は、いくつかの方法で実現できます。
単一要素の削除
ベクトルから単一要素を削除するには、erase() 関数を使用します。この関数は、削除する要素へのイテレータを受け取ります。例:
std::vector<int> vec; vec.push_back(6); vec.push_back(-17); vec.push_back(12); // Deletes the second element (vec[1]) vec.erase(std::next(vec.begin()));
std::next() 関数は、反復子を目的のインデックスに進めるために使用されます。
複数の要素の削除
複数の要素を一度に削除するには、反復子の範囲を指定して Erase() 関数を使用します。範囲は 2 つの反復子によって指定されます。1 つは削除される最初の要素を指し、もう 1 つは削除される最後の要素の直後の要素を指します。例:
// Deletes the second through third elements (vec[1], vec[2]) vec.erase(std::next(vec.begin(), 1), std::next(vec.begin(), 3));
以上がC std::vector からインデックスによって要素を効率的に削除するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。