SHOEISHA iD

※旧SEメンバーシップ会員の方は、同じ登録情報(メールアドレス&パスワード)でログインいただけます

CodeZine編集部では、現場で活躍するデベロッパーをスターにするためのカンファレンス「Developers Summit」や、エンジニアの生きざまをブーストするためのイベント「Developers Boost」など、さまざまなカンファレンスを企画・運営しています。

特集記事

Visual C++ 2010に追加されたSTLアルゴリズム

── Visual C++ バージョン10で拡充された関数群


  • X ポスト
  • このエントリーをはてなブックマークに追加

is_heap, is_heap_until

template<class RandomAccessIterator, class Predicate>
  bool is_heap(RandomAccessIterator first, RandomAccessIterator last, Predicate pred);

 predが示す大小関係に基づき、シーケンス[first,last)がヒープ化されていればtrueを返します。predが省略されていた場合、operator<が適用されます。

template<class RandomAccessIterator, class Predicate>
  RandomAccessIterator is_heap_until(RandomAccessIterator first, RandomAccessIterator last, Predicate pred);

 is_heap(first,mid,pred)がtrueとなる最大のmidを返します。predが省略されていた場合、operator<が適用されます。

……つづき
  // is_heap
  make_heap(c.begin(), c.end());
  result = is_heap(c.begin(), c.end());
  assert( result );
  pop_heap(c.begin(), c.end());
  result = is_heap(c.begin(), c.end());
  assert( !result );

  // is_heap_until
  iter = is_heap_until(c.begin(), c.end());
  assert( distance(c.begin(), iter) == 4 );
……つづく

iota

template<class ForwardIterator,	class T>
  void iota(ForwardIterator first, ForwardIterator last, T value);

 これだけ<numeric>に定義されています。シーケンス[first,last)に対し、

*first = value; ++first; ++value;

を繰り返します。たとえばint data[5]に対しiota(data, data+5, 0)するとdata[]に{ 0, 1, 2, 3, 4 }がセットされます。

……つづき
  // iota
  iota(c.begin(), c.end(), 1);
  assert ( accumulate(c.begin(), c.end(), 0) == 15 );
}
……おしまい。

この記事は参考になりましたか?

  • X ポスト
  • このエントリーをはてなブックマークに追加
特集記事連載記事一覧

もっと読む

この記事の著者

επιστημη(エピステーメー)

C++に首まで浸かったプログラマ。Microsoft MVP, Visual C++ (2004.01~2018.06) "だった"りわんくま同盟でたまにセッションスピーカやったり中国茶淹れてにわか茶...

※プロフィールは、執筆時点、または直近の記事の寄稿時点での内容です

この記事は参考になりましたか?

この記事をシェア

  • X ポスト
  • このエントリーをはてなブックマークに追加
CodeZine(コードジン)
https://codezine.jp/article/detail/5206 2010/06/22 10:55

おすすめ

アクセスランキング

アクセスランキング

イベント

CodeZine編集部では、現場で活躍するデベロッパーをスターにするためのカンファレンス「Developers Summit」や、エンジニアの生きざまをブーストするためのイベント「Developers Boost」など、さまざまなカンファレンスを企画・運営しています。

新規会員登録無料のご案内

  • ・全ての過去記事が閲覧できます
  • ・会員限定メルマガを受信できます

メールバックナンバー

アクセスランキング

アクセスランキング