1. 最小值和最大值 在一个有n个元素的集合中,需要做n−1次比较才能确定其最小(大)元素。如果要同时找出最小值和最大值,通常的做法是对每一个输入的元素都与已知的min和max作比较,这样相当于独立完成两趟查找进行2(n−1)次比较。事实上,只要记录已知的min和max,每次取2个元素进行比较,然后较小的和min进行比较,较大的和max进行比较,这样就实现了对每两个元素进行3次比较,总共只需要3⌊n/2⌋次比较。这种算法虽然也是渐近为O(n)的算法,但从比较次数来看要比暴力求解快上约25%。 2. 随机化选择算法(选择第i小的算法) 随机选择算法是一种随机的分治算法,在进行主元划分之后,快速排序会递归处理划分的两边,而随机化选择算法只处理划分的其中一边。该算法的可以以O(n)的时间找到第i小的元素。