直接选择序列的方法解本题,但是最坏时间效率是O(n*n),故此不能达到0MS。
使用删除优化,那么就可以达到0MS了。
删除优化就是当需要删除数组中的元素为第一个元素的时候,那么就直接移动数组的头指针就可以了,那么时间效率就是O(1)了,而普通的删除那么时间效率是O(n),故此大大优化了程序。
如何直接选择第k个序列,可以参考本博客的Leetcode题解。Leetcode题有个一模一样的题目。不过没有使用删除优化。
?
看见本题的讨论中基本上都是使用STL解,还有沾沾自喜的家伙,不过使用STL解决本题虽然是可以,但是那是因为本题的数据很弱;
因为使用STL的时间效率是O(n*m),其中n可能是1000, 而m可能是10000,故此会达到1千万的数据处理,随便增加个大数据用例就会超时。
故此使用STL来解决本题其实是很次,很初级的解法了。
?
?
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
?
?