摘要:
应该使用某种数据结构保存迄今最大的100个数。每读到一个新数时,将新数和保存的100个数中的最小一个相比较,如果新数更大些,则替换。这样扫描一遍100w个数也就获得了最大的100个数。对于保存的100个数的数据结构,应该在最小复杂度的条件下满足1)可以获得最小的数;2)将最小数替换为另一个数后可以重新调整,使其可以满足条件1。可见小根堆可以满足这些条件。所以应该采用小根堆+扫描的方法。http://hi.baidu.com/mianshiti/blog/item/37652f27a3ac4320d5074252.html 阅读全文
摘要:
题目:有一个特殊的链表,其中每个节点不但有指向下一个节点的指针pNext,还有一个指向链表中任意节点的指针pRand(可能为空,也有可能为自身),如何拷贝这个特殊链表?思路:拷贝pNext指针非常容易,所以题目的难点是如何拷贝pRand指针。假设原来链表为A1 -> A2 ->... -> An,新拷贝链表是B1 -> B2 ->...-> Bn。为了能够快速的找到pRand指向的节点,并把对应的关系拷贝到B中。我们可以将两个链表合并成A1 -> B1 -> A2 -> B2 -> ... -> An -> Bn。从A1节 阅读全文