反復子の消去によるベクトルの消去
プログラミングでは、データ構造を効率的に走査して操作することが重要です。 C の一般的な動的コンテナである Vector は、柔軟性と拡張機能を提供します。ただし、反復中に要素を消去すると、予期しない結果が生じる可能性があります。
次の例を考えてみましょう:
int main() { vector<int> res; res.push_back(1); vector<int>::iterator it = res.begin(); for( ; it != res.end(); it++) { it = res.erase(it); //if(it == res.end()) // return 0; } }
上記のコードは、反復中にベクトル 'res' からすべての要素を消去することを目的としています。 。ただし、最後の要素を消去するときにエラーが発生します。これは、「res.erase(it)」によって返されるイテレータが次の有効な要素 (この場合は「res.end()」) を指しているためです。
この問題を解決するには、次を使用できます。条件文のない while ループ。
while (it != res.end()) { it = res.erase(it); }
これにより、すべての要素が完了するまでループが継続されます。
あるいは、何らかの条件に基づいて特定の要素のみを消去する必要がある場合は、次のアプローチを使用できます。
for ( ; it != res.end(); ) { if (condition) { it = res.erase(it); } else { ++it; } }
ベクトル操作にイテレータを使用する場合、これが重要であることを覚えておいてください。 「res.erase(it)」がどのように動作するかを理解し、それに応じてループを調整して予期しない動作を防止します。
以上が反復中に C ベクトルから要素を安全に消去するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。