+ 3

Priority_queue Vs make_heap

Problem statement : we have a vector as an input. task is to A. find out first two maximum numbers B. remove biggest number from vector C. add number to vector which is abdolute difference of two numbers found in step A D. print two numbers found in step A repeat steps A to D three times Query : What is best method to achieve the same ? Method1 or Method 2? i.e. priority_queue or make_heap ? Reference code : https://code.sololearn.com/c0r55VJ1GZz6/?ref=app

1st Jun 2021, 9:30 PM
Ketan Lalcheta
Ketan Lalcheta - avatar
3 Antworten
+ 2
iirc priority queues are usually implemented as heaps so without knowing better I'm sure both are fine and equally performant. I think I'm partial towards priority queues because what you are doing sounds exactly like what that data structure is designed to do. Never hurts to run some performance benchmarks though. :) Or if you want to optimize hard you could simply grab the 6 largest numbers in your list and produce the desired output based on that. That must be more performant than building a heap from the entire input list, though both approaches are O(n).
1st Jun 2021, 10:36 PM
Schindlabua
Schindlabua - avatar
2nd Jun 2021, 1:40 AM
Edward Finkelstein
Edward Finkelstein - avatar
2nd Jun 2021, 11:40 AM
Ketan Lalcheta
Ketan Lalcheta - avatar