The Algorithm
1. Sort the array from 0 to n-1
2. Return the n-2th element
---
So you can do your regular sorting thing and get the result.
I would like to use this opportunity to introduce you to some more of STL.
Check the program
There is a legacy trick of finding the size of an array in that problem.
Noticed how we did -
sizeof(heights)/sizeof(int)
to get the number of elements in the array!
Then, while converting that array into a vector, we need to give the range of the array. By range I mean, a pointer (or an iterator) from the beginning of the array to the end of the array. Now 'heights' will give us the pointer to the beginning of the array and 'heights + n' to the end.
But will 'heights + n' always give us the pointer to the end of the array?
It will in our case, but it wont for other arrays of other types.
Can you tell why?
No comments:
Post a Comment