ホームページ >バックエンド開発 >C++ >C std::vector からインデックスによって要素を効率的に削除するにはどうすればよいですか?

C std::vector からインデックスによって要素を効率的に削除するにはどうすればよいですか?

Mary-Kate Olsen
Mary-Kate Olsenオリジナル
2024-12-17 01:58:25219ブラウズ

How Do I Efficiently Delete Elements from a C   std::vector by Index?

インデックスによる 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 サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。