Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • Home
  • SEARCH
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 186707
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 11, 20262026-05-11T15:41:39+00:00 2026-05-11T15:41:39+00:00

typedef pair<double, double> dd; const double epsilon = 1e-6; struct sort_by_polar_angle { dd center;

  • 0
  typedef pair<double, double> dd;     const double epsilon = 1e-6;    struct sort_by_polar_angle {      dd center;      // Constuctor of any type      // Just find and store the center      template<typename T> sort_by_polar_angle(T b, T e) {          int count = 0;         center = dd(0,0);          while(b != e) {                      center.first += b->first;                     center.second += b->second;                b++;              count++;         }                 double k = count ? (1.0/count) : 0;         center.first *= k;                center.second *= k;    }     // Compare two points, return true if the first one is earlier     // than the second one looking by polar angle     // Remember, that when writing comparator, you should     // override not ‘operator <’ but ‘operator ()’     bool operator () (const dd& a, const dd& b) const {          double p1 = atan2(a.second-center.second, a.first-center.first);          double p2 = atan2(b.second-center.second, b.first-center.first);          return p1 + epsilon < p2;     }    };   // ...   vector < dd >  points;   sort(all(points), sort_by_polar_angle(all(points)));  

When sort_by_polar_angle() is called, is it function as a construnctor? How the overloaded operator () correctly used?

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. 2026-05-11T15:41:40+00:00Added an answer on May 11, 2026 at 3:41 pm

    When you call sort_by_polar_angle() in the sort() function, you are creating a temporary object of type sort_by_polar_angle (i.e. its constructor is called). Inside the sort algorithm, the functor object you passed is used something like functor() which will be translated into functor.operator().

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Ask A Question

Stats

  • Questions 130k
  • Answers 130k
  • Best Answers 0
  • User 1
  • Popular
  • Answers
  • Editorial Team

    How to approach applying for a job at a company ...

    • 7 Answers
  • Editorial Team

    How to handle personal stress caused by utterly incompetent and ...

    • 5 Answers
  • Editorial Team

    What is a programmer’s life like?

    • 5 Answers
  • Editorial Team
    Editorial Team added an answer See my answer to this question: How to decide where… May 12, 2026 at 6:05 am
  • Editorial Team
    Editorial Team added an answer BIND. Plenty of documentation, and works just fine if you… May 12, 2026 at 6:05 am
  • Editorial Team
    Editorial Team added an answer Sounds like a persistent cache. Let me guess: you have… May 12, 2026 at 6:05 am

Related Questions

Right now I am using std::pair to represent a 2d point in c++. However,
While migrating a program from windows in linux I encountered a problem using the
How can I use BOOST_FOREACH efficiently (number-of-character/readability-wise) with a boost::ptr_map? Kristo demonstrated in his
I have a generic function: void ImageAlbum::ExpressButtonPressed( boost::function< void ( thumb::PhotoPrintThumbnail*, thumb::PhotoPrintFormat, thumb::PhotoPrintQuantity )

Trending Tags

analytics british company computer developers django employee employer english facebook french google interview javascript language life php programmer programs salary

Top Members

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.