2
#include <algorithm>
#include <iostream>
#include <iterator>
#include <string>
#include <vector>
#include <utility>

using namespace std;

typedef pair<int,int> Pair;

inline bool less_than_second( const Pair& b1, const Pair& b2 ){
   return b1.second < b2.second;
}

int main()
{
   const int SP1[] = { 2,53,21,55,36,5,1};
   const int EP1[] = { 18, 20, 26, 30, 41,1,5 };
         int i;


   const int num_pairs = sizeof( SP1 ) / sizeof( SP1[0] );
    vector<int> sm(num_pairs);

      // vector <int> SP;

   vector<Pair> pair( num_pairs );
   transform( EP1, EP1+num_pairs, SP1,pair.begin(), make_pair<int,int> );// MAKE PAIR

   sort( pair.begin(), pair.end() );

   sort( pair.begin(), pair.end(), less_than_second );

   vector<Pair>::const_iterator pair_end = pair.end();
    vector<int> SP,EP;
    vector<int>::iterator low,up;

   for( vector<Pair>::const_iterator ptr = pair.begin();ptr != pair_end; ++ptr )
   {

            int SP = ptr->second;
        int EP = ptr->first;

      cout<<"("<<SP<<","<<EP<<")\n";
      } 
   //cout<<"("<<SP<<","<<EP<<")\n";
   low=lower_bound (SP.begin(), SP.end(), 20); 
   up= upper_bound (SP.begin(), SP.end(), 20);

  cout << "lower_bound at position " << int(low- SP.begin()) << endl;
  cout << "upper_bound at position " << int(up - SP.begin()) << endl;


   up= upper_bound (pair.begin(), pair.end(), 20);                


  cout << "upper_bound at position " << int(up - pair.begin()) << endl;

   getchar();
}

ペア ベクトルを並べ替え、ペア内のベクトルの 1 つの upper_bound の値を取得しようとしていますが、位置 = 0 で upper_bound が得られます。

私はC ++の初心者であり、学びたいと思っています。このコードの修正にご協力ください。ありがとうございました

4

1 に答える 1

2

SP私が知る限り、ベクトルにデータを入れたことはありません。あなたの代わりにint SP = ptr->second;を意味する可能性がありますSP.push_back(ptr->second);

ちなみに、並べ替えは安定していないためsort( pair.begin(), pair.end() );、述語で並べ替える前に呼び出しても意味がありません。

最後に、The Definitive C++ Book Guide and List のいずれかの本を手に取り、言語の学習に役立てることをお勧めします。

于 2011-08-29T05:13:28.637 に答える