[解決済み】逆イテレータでeraseを呼び出す方法
2022-04-09 04:28:14
質問
このようなことをしようとしています。
for ( std::list< Cursor::Enum >::reverse_iterator i = m_CursorStack.rbegin(); i != m_CursorStack.rend(); ++i )
{
if ( *i == pCursor )
{
m_CursorStack.erase( i );
break;
}
}
しかし、erase はイテレータを取り、逆イテレータは取りません。逆イテレータを通常のイテレータに変換する方法、またはリストからこの要素を削除する他の方法はありますか?
どのように解決するのですか?
さらに調べてテストした結果、解決策が見つかりました。どうやら規格[24.4.1/1]によると、i.base()とiの関係は次のようになっている。
&*(reverse_iterator(i)) == &*(i - 1)
から ドブス博士の記事 ):
そのため、base()を取得する際にオフセットを適用する必要があります。したがって、解決策は
m_CursorStack.erase( --(i.base()) );
EDIT
C++11用にアップデートしました。
リバースイテレータ
i
は変更しない。
m_CursorStack.erase( std::next(i).base() );
リバースイテレータ
i
が進んでいます。
std::advance(i, 1);
m_CursorStack.erase( i.base() );
私は、この方法が以前の解決策よりもずっと分かりやすいと思います。お好きなほうをお使いください。
関連
-
[解決済み】C++コンパイルタイムエラー:数値定数の前に期待される識別子
-
[解決済み】変数 '' を抽象型 '' と宣言できない。
-
[解決済み】浮動小数点例外エラーが発生する: 8
-
[解決済み] 文字列の単語を反復処理するにはどうすればよいですか?
-
[解決済み] 1ビットのセット、クリア、トグルはどのように行うのですか?
-
[解決済み] 要素ごとの加算は、結合ループよりも分離ループの方がはるかに高速なのはなぜですか?
-
[解決済み] std::stringをintに変換するにはどうしたらいいですか?
-
[解決済み】画像処理。コカ・コーラ缶」認識のためのアルゴリズム改良
-
[解決済み] Intel CPU の _mm_popcnt_u64 で、32 ビットのループカウンターを 64 ビットに置き換えると、パフォーマンスが著しく低下します。
-
[解決済み】std::listを繰り返しながら要素を削除することは可能ですか?
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み】coutはstdのメンバではない
-
[解決済み] エラーが発生する。ISO C++は型を持たない宣言を禁じています。
-
[解決済み】C++でユーザー入力を待つ【重複あり
-
[解決済み】C++でランダムな2倍数を生成する
-
[解決済み] 非常に基本的なC++プログラムの問題 - バイナリ式への無効なオペランド
-
[解決済み] 解決済み] `pthread_create' への未定義の参照 [重複] [重複
-
[解決済み】Visual Studioのデバッガーエラー。プログラムを開始できません 指定されたファイルが見つかりません
-
[解決済み] 配列のベクトルを扱う正しい方法
-
[解決済み] スタックアロケーションにより初期化されていない値が作成された
-
[解決済み】マップを反復しながら削除する方法とは?