1. template <class RandomAccessIterator>                                             
  2. inline void make_heap(RandomAccessIterator first, RandomAccessIterator last) {    
  3.     __make_heap(first, last, value_type(first), distance_type(first));            
  1. template <class RandomAccessIterator, class T, class Distance>                    
  2. void __make_heap(RandomAccessIterator first, RandomAccessIterator last,
  3.                  T*, Distance*) {                                                 
  4.     if(last - first < 2) return;                                                  
  5.     Distance len = last - first;                                                  
  6.     Distance parent = (len - 2)/2;                                                
  7.                                                                                   
  8.     while(true) {                                                                 
  9.         __adjust_heap(first, parent, len, T(*(first + parent)));                  
  10.         if(parent == 0) return;                                                   
  11.         --parent;                                                                 
  12.     }                                                                             
  13. }                                                                   

注:__adjust_heap源码请见http://zxn990.blog.51cto.com/4253193/1165524