0

宛先ベクターに挿入する必要がありますが、ベクターの物乞いからではなく、オフセットを使用します。これは私の現在のコードですが、宛先ベクトルは最初の要素から埋められます。特定の位置から挿入するために、オフセット変数を利用したい。

何か提案はありますか?ありがとう

明確にするために、ソースではなく、宛先ベクトルでオフセットを使用したいと考えています。

  #include <cstdlib>
  #include <stdlib.h>
  #include <map>
  #include <vector>
  #include <boost/lexical_cast.hpp>
  #include <algorithm>
  #include<iterator>

  using namespace std;

  std::string intToStr(int i){

  return boost::lexical_cast<std::string>(i);
  }

  struct Movie
  {
  Movie()
      : id(0), title("title") { }

  Movie(int id, const std::string &title)
      : id(id), title(title) { }


  int id;            //!< item index
  std::string title; //!< item title
  };

  struct GetTitle { std::string operator()(const Movie& cat) const { return cat.title; } };

  int main(int argc, char** argv) {

  int offset = 5;

  std::vector<Movie> p_playlist;

    for (int i = 0; i < 20; i++)
      p_playlist.push_back(Movie(i, std::string("Name ") + intToStr(i)));


  std::vector<string> mEntries;
  std::transform(p_playlist.begin(), p_playlist.end(),   std::back_inserter(mEntries) , GetTitle());


  for(int i=0; i < mEntries.size(); i++)
    cout << mEntries[i] << endl;
4

2 に答える 2

1

宛先ベクトルに要素がない場合はback_inserter、もちろん最初の要素から挿入されます。を呼び出すだけでpush_back、魔法は何もありません。したがって、最初の N 要素をback_insert残りの要素より前に挿入する必要があります。

std::vector<string> mEntries;
insertFirstNElems(mEntries);
std::transform(p_playlist.begin(), p_playlist.end(),   std::back_inserter(mEntries) ,    GetTitle());

//... for example:
void insertFirstNElems(std::vector<string>& vec) {
  vec.resize(42, "meow");
}
于 2013-05-27T10:36:43.997 に答える